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;
}