版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
高級程序設計語言A卷答案(15分)試編寫一個C++程序?qū)崿F(xiàn)求兩個數(shù)的最大公約數(shù)和最小公倍數(shù)。要求兩個數(shù)字必須用隨機數(shù)生成。答案#include<iostream>#include<time.h>usingnamespacestd;intgcd(intx,inty){ intr; while(x%y!=0) { r=x%y;x=y;y=r; } returny;}intlcm(intx,inty){ returnx*y/gcd(x,y);}voidmain(){ srand(time(0)); inta=rand(),b=rand(); cout<<"輸出兩個正整數(shù):"<<a<<'\t'<<b; cout<<"最大公約數(shù)為:"<<gcd(a,b)<<endl<<"最小公倍數(shù)為:"<<lcm(a,b)<<endl;}備注:最大公約數(shù)也可以寫成intgcd(inta,intb){if(a%b==0)returnb;returngcd(b,a%b);}或intgcd(intx,inty){ intt,r;while(x!=y) {if(x>y)x=x-y
;elseif(y>x)y=y-x
;} returny;}(15分)編寫遞歸函數(shù)實現(xiàn)如下函數(shù)。答案#include<iostream>
usingnamespacestd;
doubleP(intn,intx)
{
if(n==0)
return1;
elseif(n==1)
returnx;
elseif(n>1)
return((2*n-1)*x*P(n-1,x)-(n-1)*P(n-2,x))/n;
}
voidmain()
{
intx,y;
cin>>x>>y;
cout<<P(x,y)<<endl;
}(10分)編寫一函數(shù)intSubStrNum(char*str,char*substr),實現(xiàn)統(tǒng)計字符串substr在字符串str中出現(xiàn)的次數(shù)。答案#include<iostream>usingnamespacestd;intSubStrNum(char*str,char*substr){ intNum=0,h1,h2,p1=0,p2; h1=strlen(str); h2=strlen(substr); while(p1<h1) { p2=0; while(str[p1]==substr[p2]&&p2<h2&&p1<h1) p1++,p2++; if(p1==h1&&p2<h2) break; if(p2==h2) Num++; else p1=p1-p2+1; } returnNum;}voidmain(){ charstr[200],substr[20]; cin>>str; cin>>substr; cout<<endl;}voidOutput(Students[],intn){ intt=0,ss=0,s1=0,s2=0,s3=0; for(inti=0;i<n;i++) { s1+=s[i].score1; s2+=s[i].score2; s3+=s[i].score3; if(sum[i]>ss) ss=sum[i]; } cout<<"第一門平均成績?yōu)椋?<<s1/n<<'\n'<<"第二門平均成績?yōu)椋?<<s2/n<<'\n'<<"第三門平均成績?yōu)椋?<<s3/n<<endl; for(i=0;i<n;i++) { if(sum[i]==ss) cout<<"最高分學生是:"<<s[i].name<<'\t'<<"平均分是:"<<ss/3.0<<endl; } }voidmain(){ StudentS[M]; Input(S,10); Output(S,10);}(10分)設計一個程序,利用友元函數(shù)計算平面上兩點之間的距離。根據(jù)給定的類定義實現(xiàn)其友元函數(shù),并用主函數(shù)進行測試。提示:Point定義classPoint{public: Point(intxx=0,intyy=0) { X=xx,Y=yy; } voidDisplay() { cout<<X<<'\t'<<Y<<endl; } friendfloatdis(Point&M,Point&N);private: intX,Y;};答案#include<iostream>#include<cmath>usingnamespacestd;classPoint{public: Point(intxx=0,intyy=0) { X=xx,Y=yy; } voidDisplay() { cout<<X<<'\t'<<Y<<endl; } friendfloatdis(Point&M,Point&N);private: intX,Y;};floatdis(Point&M,Point&N){ returnsqrt((M.X-N.X)*(M.X-N.X)+(M.Y-N.Y)*(M.Y-N.Y));}voidmain(){ PointA(1,2),B(3,5); cout<<"兩點之間距離為:"<<dis(A,B)<<endl;}(20分)設計一個用于人數(shù)管理的“People(人員)”類。由于考慮到通用性,這里只抽象出所有類型人員都具有的屬性:number(編號)、sex(性別)、birthday(出生日期)、id(身份證號)。其中“出生日期”聲明為一個已給定的“日期類”類型,身份證號為18位。要求包括:利用給定的條件,將People類定義完整。(4分)在類外實現(xiàn)對人員信息的錄入和顯示。(8分)在類定義中添加一個析構(gòu)函數(shù)。(2分)在類外實現(xiàn)成員函數(shù)的功能。(6分)提示:#include<iostream>#include<string>usingnamespacestd;classDate//日期類{private: intyear,month,day;public: Date(){}//默認構(gòu)造 Date(inty,intm,intd)//帶參構(gòu)造 { year=y,month=m, day=d; } voidset() { cin>>year>>month>>day; } voiddisplay()//顯示函數(shù) { cout<<year<<"年"<<month<<"月"<<day<<"日"; }};classPerson//人員類{private: {此部分填寫類的數(shù)據(jù)成員}public: Person(){}//默認構(gòu)造 Person(intn,inty,intm,intd,charid[18],chars='m'):birthday(y,m,d); Person(Person&p); voidinput(); voidoutput();};主函數(shù)如下:voidmain(){ Personp1; p1.input(); p1.output(); cout<<endl; Personp2(5,2001,3,21,,'m'); p2.output();}答案#include<iostream>#include<string>usingnamespacestd;classDate//日期類{private: intyear,month,day;public: Date(){}//默認構(gòu)造 Date(inty,intm,intd)//帶參構(gòu)造 { year=y,month=m, day=d; } voidset() { cin>>year>>month>>day; } voiddisplay()//顯示函數(shù) { cout<<year<<"年"<<month<<"月"<<day<<"日"; }};classPerson//人員類{private: intnum;charsex; Datebirthday;charID[18];public: Person(){}//默認構(gòu)造 Person(intn,inty,intm,intd,charid[18],chars='m'):birthday(y,m,d)//有默認值的帶參構(gòu)造 { num=n; sex=s; strcpy(ID,id); } Person(Person&p)//拷貝構(gòu)造 { num=p.num; sex=p.sex; birthday=p.birthday; strcpy(ID,p.ID); } voidinput()//輸入函數(shù) { cout<<"錄入數(shù)據(jù):"<<endl; cout<<"編號:"; cin>>num; cout<<"性別(m/f):"; cin>>sex; cout<<"生日:"; birthday.set(); cout<<"身份證號:"; cin>>ID; ID[18]='\0'; cout<<endl; } voidoutput()//輸出函數(shù) { cout<<"編號:"<<num<<'\n'<<"性別:"<<sex<<'\n'<<"生日:"; birthday.display(); cout<<'\n'<
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版會計人員稅務合規(guī)擔保協(xié)議3篇
- 二零二五年度地質(zhì)災害鉆孔治理協(xié)議4篇
- 二零二五年度水庫工程承包合同-壩體與水庫生態(tài)旅游開發(fā)4篇
- 2025年度代購食品代銷合同范本4篇
- 2025年度鋁合金門窗綠色制造與市場推廣合同4篇
- 二零二五年高性能混凝土采購合同標準3篇
- 2025年度城市綠地養(yǎng)護與生態(tài)平衡合同4篇
- 二零二五年度生態(tài)保護場咨詢服務協(xié)議書4篇
- 二零二五年度折疊門設計與安裝服務合同范本4篇
- 2025年新媒體品牌形象設計與傳播合作協(xié)議2篇
- 《請柬及邀請函》課件
- 中小銀行上云趨勢研究分析報告
- 機電安裝工程安全培訓
- 遼寧省普通高中2024-2025學年高一上學期12月聯(lián)合考試語文試題(含答案)
- 青海原子城的課程設計
- 常州大學《新媒體文案創(chuàng)作與傳播》2023-2024學年第一學期期末試卷
- 麻醉蘇醒期躁動患者護理
- 英語雅思8000詞匯表
- 小學好詞好句好段摘抄(8篇)
- JT-T-1059.1-2016交通一卡通移動支付技術(shù)規(guī)范第1部分:總則
- 《茶藝文化初探》(教學設計)-六年級勞動北師大版
評論
0/150
提交評論