2022年高級程序設(shè)計語言C++期末考試卷及答案2套_第1頁
2022年高級程序設(shè)計語言C++期末考試卷及答案2套_第2頁
2022年高級程序設(shè)計語言C++期末考試卷及答案2套_第3頁
2022年高級程序設(shè)計語言C++期末考試卷及答案2套_第4頁
2022年高級程序設(shè)計語言C++期末考試卷及答案2套_第5頁
已閱讀5頁,還剩10頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、PAGE 高級語言程序設(shè)計 I 試卷 (A) 第 PAGE 12 頁 共 NUMPAGES 15 頁姓名 學(xué)號 學(xué)院 專業(yè) 座位號 ( 密 封 線 內(nèi) 不 答 題 )密封線線_ _ 誠信應(yīng)考,考試作弊將帶來嚴(yán)重后果! 期末考試 高級程序設(shè)計語言C+試卷 注意事項:1. 考前請將試卷和答題紙密封線內(nèi)各項填寫清楚; 2. 所有答案寫在答題紙上,否則無效; 3試卷和答題紙同時提交; 4考試形式:閉卷; 5. 本試卷共五大題,滿分100分,考試時間120分鐘。題 號一二三四五總分得 分評卷人單項選擇題(每小題2分,共26 分)1. 由C+目標(biāo)文件連接而成的可執(zhí)行文件的缺省擴展名為( C )。(A)cp

2、p(B)obj(C)exe(D)dll2. 下列選項中全部都是C+關(guān)鍵字的選項為( B )。(A)cpp int break(B)int char new (C)break CASE sizeof (D) switch float integer3. 下列四個選項中,不能交換變量a和b的值是( B )。(A)a=a-b, b=a+b, a=b-a;(B) t=a, a=b, t=b, b=a;(C)t=a, a=b, b=t;(D) t=b, a=b, b=a;4. 字符串Hello,nHi041包含的有效字符個數(shù)為( D )。 (A)14(B)13(C)12(D) 105. 下列代碼執(zhí)行的結(jié)

3、果是( B )。int x = 3510; double y = x/100*100; cout y;(A)3510(B)3500(C) 3000 (D) 16. 已知int i=3;下面語句執(zhí)行的循環(huán)次數(shù)是( B )。 do i-; coutiendl; while( i != 1 ); (A)1(B)2(C)3(D) 無限次7. 假設(shè)int a=1, b=2, &ra=a, &rb=b; 下列正確的語句是( B )。 (A)&ra=a;(B)rb = ra;(C)&rb=&ra;(D) *rb=*ra;8. 在下面的函數(shù)聲明中,存在著語法錯誤的是( D )。(A)void f( int a

4、, int ) (B) void f( int a, int b )(C)void f(int a, int b=5) (D) void f( int a; int b )9. 若有定義語句: int a23,*p3; 則以下語句中正確的是( C )。(A)p=a;(B)p0=a;(C)p0=&a12;(D) p1= &a;10. 下列代碼輸出結(jié)果為( D )int* arr = new int10; cout no=3011;(C)(*p).no=3011;(D) *p.no=3011;13. 要求打開文件“D:file.dat”,可寫入數(shù)據(jù),正確的語句是( D )。(A) ifstream

5、 infile( “D:file.dat”, ios:in );(B) ifstream infile( “D:file.dat”, ios:in);(C) ofstream infile( “D:file.dat”, ios:out);fstream infile( “D:file.dat”, ios:in|ios:out );二、簡答題 (共12分)1、(3分) 有以下語句:int a = 63; double b = 3.456789 ; coutsetfill(#)setw(6)hexansetprecision(5) bendl; 輸出顯示什么?#3f3.4568 2、(3分) 有說

6、明int A3 5; 寫出兩個不同形式的表示A13元素值的表達(dá)式。 A13 * (A1+3) * (*(A+1)+3)3. (3分)設(shè)有說明double a6= 0 , *b = new double 6; sizeof(a), sizeof(b)的值各是多少?并分析結(jié)果原因。 48 44、(3分)設(shè)有函數(shù)調(diào)用語句 Count(A ,N, right, negative); 功能是由參數(shù)right, negative返回統(tǒng)計數(shù)組A 的N個元素中正整數(shù)和負(fù)整數(shù)的個數(shù)。對應(yīng)的函數(shù)原型是什么?void Count( int * , int, int &, int &);三、讀程序?qū)懡Y(jié)果(共6題,每題

7、 45分,共28分)1、(4分):#includeconst int N=5;void main()int aN = 8,6,5,4,1 , i, temp;for( i=0; iN/2; i+ ) temp = ai; ai = aN-i-1; aN-i-1 = temp; for( i=0; iN; i+ )coutai ;答案:1 4 5 6 82、(4分)。 #includevoid fun() static int a=0; int b=0; a+=2; +b; coutatbendl; void main() for(int i=1; i4; i+) fun(); 答案:2 14

8、16 13、(4分)。#includevoid main() int i;char c; char s=abccda; for(i=1;(c=si)!= 0;i+) switch(c) case a:cout%;continue; case b:cout%;break; case c:cout*;break; case d: continue; cout#endl;答案:%#*#*#4、(5分)#includevoid func( char *p ) if( *p=0 ) return ; func( p+1 ); cout*p;void main() func(hello); 答案:olle

9、h5、(5分)。#include void func(int, int&, int *) ;void main() int x=11, y=22, z=33 ; func(1, x, &z) ; coutx y zendl; func(2, z, &y) ; coutx y zendl;void func(int a, int &b, int *c) b+=a ; *c=b-a; 答案:12 22 1112 11 136、(5分)#include#includevoid func(int *p)int t;for(int i=0;i3;i+) for(int j=i;j3;j+) t=*(p+

10、3*i+j); *(p+3*i+j)=*(p+3*j+i); *(p+3*j+i)=t; void main()int a33=1,2,3,4,5,6,7,8,9,*p,i,j;p=&a00;func(p);for(i=0;i3;i+)for(j=0;j3;j+)coutsetw(5)aij;coutendl;答案: 1 4 7 2 5 8 3 6 9四、讀程序填空(每空2分,共20 分)1以下程序的功能是:將一組數(shù)據(jù)從大到小排列后輸出,并顯示每個元素及它們在原數(shù)組中的下標(biāo)。請將程序補充完整。#include void main() int a = 38, 6, 29, 1, 25, 20,

11、6, 32, 78, 10 ; int index10; int i,j,temp; for( i=0; i10; i+ ) (1) ; indexi = i for( i=0; i= 8; i+ ) for( j = i+1;j= (2) ; j+ ) sizeof(a)/ sizeof(int)-1 或 9 if( (3) ) ai aj temp = ai; ai = aj; aj = temp; temp = indexi; indexi = indexj; indexj = temp; for( i=0; i10; i+ ) cout ai t indexi endl;2. 下面程序

12、的功能是:用字符指針作為函數(shù)的參數(shù),實現(xiàn)字符串拷貝。請將程序補充完整。#include void get_copy( char *to , char *from ) int i = 0;while( fromi != 0 ) toi = (4) ; fromi i+; (5) ; toi = 0void main( ) char str20;get_copy( (6) , “I am a student.”); strcoutstrendl; 3. 下面程序的功能是:將兩個遞增有序的數(shù)組a和b合并成一個數(shù)組c,并仍保持遞增次序。請將程序補充完整。 #include void main( ) i

13、nt a6 = 1,3,5,7,9,11, b5= 2,4,6,8,10, c11; int i, j, k;i=j=k=0; while(i6 & j5)if(aibj) ck+=ai+; else ck+=bj+;while( (7) ) i6ck+=ai+;while(j5) (8) ; ck+=bj+for(k=0;k11;k+) cout ckends;4. 下面程序的功能是:建立一個文本文件。請將程序補充完整。#include void main() (9) ; ofstream outstufoutstuf.open( i:test.dat ,ios:out) ; outstuf

14、 This is a test.n ; outstuf. (10) ; close()五、編程題(共14分)1.( 6 )編寫程序其功能是輸出1000以內(nèi)個位數(shù)為6且能被3整除的所有正整數(shù)。要求輸出格式為:每一行顯示10個數(shù),每個數(shù)的寬度為5。圖1是輸出效果。#include 圖1#include void main ( ) cout 1000以內(nèi)個位數(shù)為6且能被3整除的所有正整數(shù):nn; for (int i=0,j=0 , k=0 ; i 100 ; i+ ) j = i * 10 + 6 ; if ( j % 3 ) continue; cout setw(5)j; if( (+ k %

15、10 )= 0 ) coutendl; coutendl;2、(8分)以下程序用隨機函數(shù)生成兩位整數(shù),取M個各不相等的數(shù)據(jù),按生成順序存放在數(shù)組a中。圖2是生成20個數(shù)據(jù)的顯示效果。請按照題意編寫insert函數(shù)及填寫函數(shù)原型。#include圖2生成的數(shù)組#include#include #include_;/insert函數(shù)原型int insert( int *ap, int k, int n ); void main() const int M=20; int n, i=0; int aM= 0 ; srand(time(0); while (iM) do n=rand()%100;wh

16、ile(n10); /生成數(shù)據(jù) if( insert( a, i, n ) ) i+; /把不相同數(shù)據(jù)插入數(shù)組a cout生成的數(shù)組:endl; for( i=1; i=M;i+ ) coutai ; if(i%10=0)coutendl; coutendl;int insert(int *ap, int k, int n) for(int j=0; jk; j+) /濾去相同數(shù) if( apj= n ) break; if(j=k) apj = n; return 1; /添加數(shù)據(jù) return 0;_ _ 一、單項選擇題。(每小題2分, 共20分) 、下列合法的變量名是( C )。(A)8

17、d (B) 1_2h(C)_int (D) file.cpp2、有說明語句: int a=0; double x=5.16; ,則以下語句中,( C )屬于編譯錯誤。(A) x=a/x; (B) x=x/a;(C) a=a%x;(D) x=x*a;3、設(shè)有:int a=7,b=5,c=3, d=1; , 則條件表達(dá)式ad?c:d的值為( )。(A)7(B) 5(C) 3(D) 14、執(zhí)行下列語句后,x的值是( ),y的值是( )。 int x, y ; x = y = 1; +x|+y ;(A)不確定 (B) 0 () () 5、下列for語句循環(huán)的次數(shù)是( B ) 。for ( int i=

18、0,x=0; !x & i=3; i+ )() 3 (B) 4 () 0 () 無限6、有函數(shù)原型 void fun( int * ); 下面選項中,正確的調(diào)用是( C )。() double x = 0.12; fun( &x );() int a = 1 ; fun( a*3.14 ); () int b = 10; fun( &b );() fun( 56 );7、關(guān)于函數(shù)定義和調(diào)用的說法正確的是( A )。(A)函數(shù)能嵌套調(diào)用,但不能嵌套定義(B)函數(shù)能嵌套調(diào)用,也能嵌套定義(C)函數(shù)不能嵌套調(diào)用,也不能嵌套定義(D)函數(shù)不能嵌套調(diào)用,但能嵌套定義8、有定義一維數(shù)組語句:int a5,

19、*p;,則下列表達(dá)式錯誤的是()。(A)p=p+1 (B)a=a+1 ()p-a ()a+9、假定有語句:int b3=1,2,0;則b22的值是()。(A) (B) () () 10、若用數(shù)組名作為調(diào)用函數(shù)的實參,則傳遞給形參的是( )。() 數(shù)組存貯首地址 () 數(shù)組的第一個元素值() 數(shù)組中全部元素的值 () 數(shù)組元素的個數(shù)二、簡答題。(共20分)有以下循環(huán)語句無法正常結(jié)束循環(huán),請找出原因。(2分)int i=100, j=0, m=0;while(1) m+=j; j+; if(j=i) break; 一程序要求統(tǒng)計未退休(男性年齡60,女性55)職工中1-3月份出生的人數(shù)。請寫出職工

20、記錄中結(jié)構(gòu)的最小定義形式,并寫出用于判斷的C+邏輯表達(dá)式。(4分)struct Employee char name20; char sex; int Byear; int Bmonth; int Bday;Employee em;/設(shè)男性=m,女性=f(em.sex=m&2007-em.Byear60| em.sex=f&2007-em.Byear55)&(em.Bmonth=1)設(shè)有說明int a4*5; 請寫出兩個表示數(shù)組a最后一個元素地址值的表達(dá)式。(3分)&a19a+19設(shè)有說明double x10= 0 , * y = new double 10; 問sizeof(x), size

21、of(y)的值各是多少?并分析結(jié)果原因。(4分)sizeof(y)的值為4。y是指針變量。設(shè)有函數(shù)調(diào)用語句 Count(a ,n, right, negative); 功能是由參數(shù)right, negative返回統(tǒng)計數(shù)組a 的n個元素中正整數(shù)和負(fù)整數(shù)的個數(shù)。對應(yīng)的函數(shù)原型是什么?(2分)void Count(int *a, int , int&, int&);void Count(int a, int , int&, int&);以下語句不能正確輸出單向鏈表的數(shù)據(jù)元素值,請找出原因。(2分)struct linkint data; link * next; ;link *head, *p;p

22、=head;while(p)coutp.data; p+; 鏈表非連續(xù)存儲,p+不能訪問后續(xù)結(jié)點。7、設(shè)有以下說明語句,請寫出3個調(diào)用函數(shù)function的語句。(3分)typedef void funType (int ,double);funType function, *fp;設(shè):int a; double x; fp=function;則可有:function(a,x);fp(a,x);(*fp)(a,x);三、閱讀程序?qū)戄敵鼋Y(jié)果(每小題4分,共20分)1、#include void main() int i, s = 0;for( i=4; i6; i+ ) switch( i )

23、case 3: s += i*i; break; case 4: s += i*i; break; case 5: s += i*i; break; default: s += 2; cout s= s endl; S=16S=412、#include void main() int i,j;for( i=1; i=3; i+ ) j=1; while (ji) cout itjendl; j+; 2131323、#include void func(int, int, int *) ;void main() int x, y, z ; func(1, 2, &x) ; func(3, x,

24、&y) ; func(x, y, &z) ; coutxendlyendlzendl ;void func(int a, int b, int *c) b-=a ; *c=b-a; 0-6-64、#include int f1(int a,int b) return a%b*5;int f2(int a,int b) return a*b;int f3(int(*t)(int, int),int a,int b) return (*t)(a, b);void main() int (*p)(int, int) ; p=f1 ; coutf3(p, 5, 6)endl ; p=f2 ; cout

25、f3(p, 7, 8)endl ;25565、#include#includevoid fNum (int w) int i; if(w0) for(i=1;i=w;i+) coutsetw(3)w; coutendl; fNum(w-1); void main() fNum(4);4 4 43 321四、程序填空題(每空2分,共20分)1、下面程序的功能是:輸入三角形的三條邊存放在變量a,b和c 中,判別它們能否構(gòu)成三角形,若能,則判斷是等邊、等腰、還是其它三角形,在橫線上填上適當(dāng)內(nèi)容。#include void main() float a, b, c ; coutabc; if ( a+

26、bc & b+ca & c+ab ) if ( 【1】 ) a=b & b=c cout等邊三角形!n; else if ( 【2】 ) a=b|a=c|b=c cout等腰三角形!n; else cout其它三角形!n; else cout不能構(gòu)成三角形!n;2、以下程序功能是輸出1000以內(nèi)個位數(shù)為6且能被3整除的所有數(shù)。請?zhí)羁铡?include void main ( ) int i, j ; for ( i=0 ; 【3】 ; i+ ) i 100 j = i * 10 + 6 ; if ( 【4】 ) continue ; j % 3 cout j ; 3、求n(n6)內(nèi)的所有偶數(shù)表

27、示為兩個素數(shù)之和,圖1為輸入12的運行結(jié)果。補充完整以下程序。提示:一個偶數(shù)n(n6)可以表示為 1+(n-1),2+(n-2),3+(n-3), #include圖1#include#include int isprime(int);void main() int num; cout=6):n;cinnum; for(int n=6; n=num; n+=2) for(int i=3;i=n/2;i+=2) if( _【5】_ ) isprime(i) & isprime(n-i)coutsetw(3)n=setw(3)i +setw(3)(n-i)endl; break ; int isp

28、rime(int n) int i, sqrtm=(int)sqrt(n); for(i=2; i=sqrtm; i+) if( _【6】_ ) return 0 ; n%i=0 _【7】_ ; return 14、以下程序是創(chuàng)建一個動態(tài)數(shù)組,數(shù)組長度由程序運行時輸入數(shù)據(jù)決定。調(diào)用隨機函數(shù)對動態(tài)數(shù)組賦初值,并輸出動態(tài)數(shù)組各元素值。請?zhí)羁铡?高級語言程序設(shè)計 I 試卷 (A) 第 PAGE 15 頁 共 NUMPAGES 15 頁#include #include#includevoid main() int n, *p= 【8】 ; NULL cout n; p= 【9】 new intn i

29、f(p=NULL) coutAllocation faiure n; return; srand(time(0) ; for( int i=0; in; i+ ) pi=rand()%100; for( 【10】 ; ap+n; a+ ) int *a=p cout*at; coutendl; delete p; 五、編程題(20分)(6分)編寫程序,打印正整數(shù)的平方和立方值。程序運行后顯示相應(yīng)的提示信息,要求輸入2個正整數(shù),然后顯示這個范圍的數(shù)據(jù)的平方和立方值。例如,分別輸入整數(shù)2和9,執(zhí)行效果如圖2所示。圖2 顯示數(shù)制對照表#include#includevoid main() int a

30、,b; cout=0 ):; cina; cout=第1個整數(shù) ):; cinb; coutsetw(12)Nsetw(12)平方setw(12)立方endl; for(int i=a; i=b; i+) coutsetw(12)isetw(12)i*isetw(12)i*i*iendl;圖3 生成數(shù)組(6分)以下程序用隨機函數(shù)生成兩位整數(shù),取M個各不相等的數(shù)據(jù),按生成順序存放在數(shù)組a中。圖3是生成20個數(shù)據(jù)的顯示效果。請依題意編寫函數(shù)insert及填寫函數(shù)原型。#include#include#includeint insert(int *ap, int k, int n); /函數(shù)原型或:int insert(int ap, int k, int n);void main() const int M=20; int n, i=

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論