1.产品抽检
题目描述
有1000台产品,编号依次为1~1000,要从中抽出15台进行抽样检测。请设计一个具有C++风格的抽样模拟程序,输出抽样结果,输出时要求每行输出5个数据,数据间’\t’分隔。(15台产品编号不重复)
【提示】产生15个1~1000间的随机数,请查阅srand()和rand()函数。
输入描述
无
输出描述
输出抽样结果,输出时要求每行输出5个数据,数据间’\t’分隔。
输入样例
无
输出样例
571 579 190 833 937
465 560 629 855 701
361 185 968 461 464
#include <iostream>
#include <stdlib.h>
#include <time.h>
using namespace std;
int main()
{
srand((int ) time(NULL));
for(int i=0,cnt=0;i<15;i++)
{
printf("%d\t",rand()%1000+1);
cnt++;
if(cnt%5==0) printf("\n");
}
return 0;
}
2. (20分) swap() -函数重载、引用作函数参数
题目描述
编写C++风格的程序,建立swap()函数,重载该函数,分别用引用和指针做形参,实现两个整型数据的互换。
输入描述
两个整数
输出描述
依次调用两个重载函数后的两个整数值
输入样例
45 90
输出样例
引用作参数调用的结果:90 45
指针作参数调用的结果:45 90
#include<iostream>
using namespace std;
void swap(int &m,int &n)
{int x;
x=m;
m=n;
n=x;
}
void swap(int *m,int *n)
{int x;
x=*m;
*m=*n;
*n=x;
}
int main()
{
int a,b;
cin>>a>>b;
swap(a,b);
cout<<"引用作参数调用的结果:"<<a<<' '<<b<<endl;
swap(&a,&b);
cout<<"指针作参数调用的结果:"<<a<<' '<<b<<endl;
return 0;
}
3. (20分) 换零钱
题目描述
编写一个C++的程序,解决换钱问题:将从键盘输入的人民币(以元为单位,可以为小数)兑换成1、2、5分的硬币,要求每种至少有一枚,有多少种换法?
输入描述
要换的钱数,以元为单元,可以是小数(double型数据)
输出描述
兑换后的换法总数
输入样例
1.5
输出样例
换法总数为:1066(中文冒号)
#include <iostream>
using namespace std;
int main()
{
double a;
int b;
cin>>a;
b=int(a*100);
int i,j,k,sum=0,cnt=0;
for(i=1;i<=b/5;i++)
for(j=1;j<=b/2;j++)
for(k=1;k<=b/1;k++)
if(i*5+j*2+k*1==b)
cnt++;
cout<<"换法总数为:"<<cnt<<endl;
return 0;
}
4. (20分) 函数重载-sroot()
题目描述
编写一个C++风格的程序,建立sroot()函数,返回其参数的立方。重载sroot()3次,让它返回整数、长整数与双精度的立方,保留8位有效数字。(实数保留有效数字位数建议使用操纵符setprecision(8),头文件iomanip,使用方法网上查看相关文档)。
用cout输出时系统自动会根据数据大小选择小数或指数形式输出。
输入描述
三个数据,分别为基本整型、长整型、双精度实型
输出描述
三个双精度数:分别为整数、长整数与双精度的立方
输入样例
12
1234
12.34
输出样例
12的立方是:1728
1234的立方是:1.8790809e+009
12.34的立方是:1879.0809
#include<iostream>
#include <iomanip>
using namespace std;
double sroot(int x)
{
return x*x*x;
}
double sroot(long x)
{return x*x*x;}
double sroot(double x)
{return x*x*x;}
int main()
{
int a;
long b;
double c;
cin>>a>>b>>c;
cout<<a<<"的立方是:"<<setprecision(8)<<sroot(a)<<endl;
cout<<b<<"的立方是:"<<setprecision(8)<<sroot(b)<<endl;
cout<<c<<"的立方是:"<<setprecision(8)<<sroot(c)<<endl;
return 0;
}