C語言考試題及答案(一)

養生護髮發表於2020-09-30

C語言(一)
一 選擇題(7分,每小題0.5分)
1.C語言源程式的基本單位是( )。
A 過程 B 函式 C 子程式 D 識別符號
2.下列程式的輸出結果是( c)。
main( )
{ int a=7,b=5;
printf("%d\n",b=b/a);
}
A 5 B 1 C 0 D不確定值
3.假設變數a,b均為整型,表示式(a=5,b=2,a>b?a++:b++,a+b)的值是(b )。
A 7 B 8 C 9 D 2
4.設a為int型變數,執行下列賦值語句後,a的取值分別是( b )。
a=125.534;
a=(int)125.521%4;
a=5<<2;
A 125,31,1 B 125,1,20 C 125,31,20 D 125.534,2,20
5.設有如下程式段,下面描述中正確的是 ( C )。
int k=10;
while(k=0) k=k-1;
A 迴圈執行一次 B迴圈是無限迴圈 C迴圈體語句一次也不執行 D迴圈體語句執行一次
6.以下程式的輸出結果為( A )。
int i; void prt( )
{
for(i=5;i<8;i++)
printf("%c",’*’);
printf("\t");
}
main( )
{for(i=5;i<=8;i++)
prt( );
}
A *** B *** *** *** *** C *** *** D * * *
7.在C語言程式中,以下說法正確的是( B)。
A函式的定義可以巢狀,但函式的呼叫不可以巢狀 B函式的定義不可以巢狀,但函式的呼叫可以巢狀 C函式的定義和函式的呼叫都不可以巢狀 D函式的定義和函式的呼叫都可以巢狀

8.以下函式呼叫語句中含有( A )個實參。
func((e1,e2),(e3,e4,e5));
A 2 B 3 C 5 D 語法錯誤
9.以下程式的輸出結果為( A )。
#define ADD(x) x*x
main( )
{int a=4,b=6,c=7,d=ADD(a+b)*c;
printf(“d=%d”,d);
}
A d=70 B d=80 C d=140 D d=700
10.已知職工記錄描述如下,在Turbo C中,系統為變數w分配(C )位元組的空間。
struct worker
{int no;
char name[20];
char sex;
union{int day;int month;int year;}
birth;
} w;
A 29 B 20 C 25 D 6
11.設有以下定義,值為5的列舉常量是( A )。
enum week{sun,mon=4,tue,wed,thu,fri,sat} w;
A tue B sat C fri D thu
12.下面選項中正確的賦值語句是(設 char a[5],*p=a;)( A )。
A p=“abcd”; B a=“abcd”; C *p=“abcd”; D *a=“abcd”;
13.設有以下程式段,則值為6的表示式是( B )。
struct st{ int n; struct st *next;};
static struct st a[3]={5,&a[1],7,&a[2],9,0 },*p;
p=&a[0];
A p+±>n B ++p->n C p->n++ D (*p).n++
14.C語言中的檔案型別只有( D )。
A 索引檔案和文字檔案兩種 B 文字檔案一種 C 二進位制檔案一種 D ASCII碼檔案和二進位制檔案兩種
二 判斷對錯,對的劃“√”,錯的劃“×”(5分,每小題0.5分)
1.在Turbo C中,整型資料在記憶體中佔2個位元組。( )
2.int i=20;switch(i/10){case 2:printf(“A”);case 1:printf(“B”);}的輸出結果為A。( )
3.break語句用在迴圈體中,可結束本層迴圈,continue語句用在迴圈體中,可結束本次迴圈。( )
4.函式的遞迴呼叫不過是一個函式直接或間接地呼叫它自身。( )
5.函式strlen(“ASDFG\n”)的值是7。( )
6.通過return語句,函式可以帶回一個或一個以上的返回值。( )
7.結構體型別只有一種。 ( )
8.char *p=“girl”;的含義是定義字元型指標變數p,p的值是字串"girl"。( )
9.若有定義:char *p(char a[10]);則p是函式名。( )
10.用fopen(“file”,“r+”);開啟的檔案"file"可以進行修改。 ( )

三 寫出下列程式的執行結果(10分,每小題2分)

1.float average (float array[10])
{int i;
float aver,sum=array[0];
for (i=1;i<10;i++)
sum=sum+array[i];
aver=sum/10;
return(aver);
}
main( )
{float score[10]={89,67.5,78,91,56,82.5,65,70,79,88},aver;
int i;
aver=average (score);
printf (“average score is %5.2f\n”,aver);
}
2.main( )
{char a[5]={‘A’,‘B’,‘C’,‘D’,‘E’},p=a,pa;
for(p=0;p<a+5;p++) printf(“%2c”,*p);
printf(“\n”);
printf(“%2c\n”,
(pa=&p));
}
3.main( )
{int a,b,s=0;
for(a=1,b=1;a<=100;a++)
{if(b>=20)
break;
if(b%31)
{b+=3;
continue;
}
b-=5;
}
printf(“a=%d\tb=%d\n”,a,b);
}
4.main()
{printf(“main( ) :%d\n”,fact(5));
fact(-5);
}
fact(int value)
{int f;
if(value<0)
{printf(“Arg error\n");
return(-1);
}
else if(value
1||value==0)
f=1;
else f=value
fact(value-1)+1;
printf(“This called value=%d\n”,f);
return f;
}
5.main( )
{int a=012,b=0x12,k=12;
char c=‘\102’,d=‘\r’;
printf(“a=%d\tb=%d\tk=%d\n”,a,b,k);
printf(“c=%c,d=%c%o\n”,c,d,a);
a=‘A’;
c=49;
printf(“a=%d\tc=%c\n”,a,c);
}
四 閱讀下列程式,在 處填入適當內容,使程式完整(8分,每個空1分)
1.有一個3*4矩陣,求其中的最大元素。
max_value( (1) )
{int i,j,max; max=array[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(array[i][j]>max)
max=array[i][j];
(2) ;
}
main( )
{int a[3][4], i,j;
for(i=0;i<3;i++)
for(j=0;j<4;j++)
(3) ;
printf(“max value is %d\n”,max_value(a));
}

2.輸入x、y兩個整數,按先大後小的順序輸出x、y。
#include “stdio.h”
main( )
{int x,y, *px,*py, (4) ;
scanf(“%d%d”,&x,&y);
(5) ;
(6) ;
if(x<y)
{p=px;
px=py;
py=p;
}
printf(“x=%d,y=%d\n”,x,y);
printf(“MAX=%d,MIN=%d\n”,*px,*py);
}
3.用選擇排序法對任意10個整數按照由小到大排序。
main()
{int a[11],i,j,k,t;
printf(“Please input 10 numbers:\n”);
for(i=1;i<11;i++) scanf("%d",&a[i]);
printf("\n");
for(i=1;i<=9;i++)
{ (7) ;
for(j=i+1;(8);j++)
if(a[j]>a[k])
k=j;
if(k!=i)
{t=a[k];
a[k]=a[i];
a[i]=t;
}
}
printf(“The sorted numbers:\n”);
for(i=1;i<11;i++)
printf("%d ",a[i]);
}
答案(一)
一 選擇題(7分,每小題0.5分)

  1. B 2. C 3. B 4. B 5. C
  2. A 7. B 8. A 9. A 10. C
  3. A 12. A 13. B 14. D
    二 判斷對錯,對的劃“√”,錯的劃“×”(5分,每小題0.5分)
    1.× 2.× 3.√ 4.√ 5.×
    6.× 7.× 8.× 9.√ 10.√
    四 閱讀下列程式,在 處填入適當內容,使程式完整(8分,每個空1分)
    1.(1)int array[3][4](int array[][4])
    (2)return(max)
    (3)scanf(“%d”,&a[i][j])
    2.(4)*p
    (5)px=&x(py=&y)
    (6)py=&y(px=&x)
    3.(7)
    (8)

C語言(二)
一 選擇題(24分,每小題2分)
1.已知函式fread的呼叫形式為fread(buffer,size,count,fp),其中buffer代表的是( )。
A 存放讀入資料項的儲存區 B 存放讀入資料的地址或指向此地址的指標
C 一個指向所讀檔案的檔案指標 D 一個整形變數,代表要讀入的資料項總數
2.以下程式的輸出結果為( )。
main( )
{int i=010,j=10;
printf("%d,%d\n",i++,j–);
}
A 11,9 B 9,10 C 8,10 D 9,9
3.設a為int型變數,執行下列賦值語句後,a的取值分別是( )。
a=125.534;a=20.0/3;
a=(int)125.521%4;a=5<<2;
A 125,6,31,1 B 125,6,1,20 C 125,6.666666,31,20 D 125.534,6.666666,2,204.設i和k都是int型別,則for迴圈語句( )。
for(i=0,k=-1;k=1;i++,k++)
printf("****\n");
A 迴圈結束的條件不合法 B 迴圈體一次也不執行
C 迴圈體只執行一次 D 是無限迴圈
5.以下程式的輸出結果為( )。
main( )
{char c;
int i;
for(i=65;i<68;i++)
{c=i+32;
switch©
{case ‘a’:case ‘b’:case ‘c’:printf("%c,",c);break;default:printf(“end”);}
}
}
A a,b,c,end B a,a,a,end C a,a,a, D a,b,c,
6.函式呼叫語句:fseek(fp,-10L,2);的含義是( )。
A 將檔案位置指標從檔案末尾處向檔案頭的方向移動10個位元組
B 將檔案位置指標從當前位置向檔案頭的方向移動10個位元組
C 將檔案位置指標從當前位置向檔案末尾方向移動10個位元組
D 將檔案位置指標移到距離檔案頭10個位元組處

7.以下程式的輸出結果為( )。
main( )
{char s1[40]=“country”,s2[20]=“side”;
int i=0,j=0;
while(s1[i]!=’\0’)
i++;
while(s2[j]!=’\0’)
s1[i++]=s2[j++];
s1[i]=0;
printf("%s\n",s1);
}
A side B country C sidetry D countryside
8.下列說法不正確的是( )。
A 主函式main中定義的變數在整個檔案或程式中有效
B 不同函式中,可以使用相同名字的變數
C 形式引數是區域性變數
D 在一個函式內部,可以在複合語句中定義變數,這些變數只在本複合語句中有效
9.在下列程式段中,列舉變數 c1的值是( )。
enum color {red,yellow,blue=4,green,white}
c1;
c1=yellow;
c1=white;
A 1 B 3 C 5 D 6
10.設有說明 int (*ptr)();其中識別符號ptr是( )。
A 是一個指向整形變數的指標 B 是一個指標,它指向一個函式值是int的函式
C 是一個函式名 D定義不合法
11.定義由n個指向整形資料的指標組成的陣列p,其正確的方式為( )。
A int p; B int (*p)[n]; C int *p[n]; D int (*p)( );
12.具有相同型別的指標型別變數p與陣列a,不能進行的操作是( )。
A p=a; B *p=a[0]; C p=&a[0]; D p=&a;
二 判斷對錯,對的劃“√”,錯的劃“×”(20分,每小題2分)
1.參加位運算的資料可以是任何型別的資料。( )
2.若有定義和語句:
int a;
char c;
float f;
scanf("%d,%c,%f",&a,&c,&f);
若通過鍵盤輸入:10,A,12.5,則a=10,c=‘A’,f=12.5。( )
3.C語言把檔案看作是一個字元(位元組)的序列。( )
4.若有巨集定義:
#define S(a,b)
t=a;
a=b;
b=t由於變數t沒定義,所以此巨集定義是錯誤的。( )
5.在Turbo C中,下面的定義和語句是合法的:file *fp;fp=fopen(“a.txt”,“r”)? )
6.若有定義:char s[ ]="china";
則Turbo C系統為陣列s開闢6個位元組的記憶體單元。( )
7.若有定義和語句:
int a[3][3]={{3,5},{8,9},{12,35}},i,sum=0;
for(i=0;i<3;i++)
sum+=a[i][2-i];
則sum=21。( )
8.若有定義和語句:
struct student {int num;char name[10]; float score;}
s[5]={{1,“lili”,98.5},{9,“xiaohua”,66}},*p=s;
printf("%d",p++);
輸出結果是1。( )
9.在程式中定義了一個結構體型別後,可以多次用它來定義具有該型別的變數。( )
10.在Turbo C中,此定義和語句是合法的:
enum aa{ a=5,b,c}bb;bb=(enum aa)5;( )
三 寫出下列程式的執行結果(36分,每小題6分)
1.main( )
{ int i=29,j=6,k=2,s;
s=i+i/j%k-9;
printf(“s=%d\n”,s);
}
2.main( )
{int x=31,y=2,s=0;
do
{s-=x
y;
x+=2;
y-=3;
}
while( x%3==0);
printf(“x=%d\ty=%d\ts=%d\n”,x,y,s);
}
3.main( )
{int a[6]={10,20,30,40,50,60},i;
invert(a,0,5);
for(i=0;i<6;i++) printf(“%d,”,a[i]);
printf(“\n”);
}
invert(int s[ ],int i,int j)
{int t;
if(i<j)
{invert(s,i+1j-1);
t=s[i];s[i]=s[j];s[j]=t;
}
}

4.#include<stdio.h> main()
{char str[ ]=“The C program”,c; int i;
for(i=2;(c=str[i])!=‘\0’;i++)
{switch©
{case ‘g’: ++i;
break;
case ‘o’: continue;
default: printf(“%c”,c);
continue;
}
printf(“*”);
}
printf(“\n”);
}
5.struct w{char low;char high; };
union u{struct w byte; short word; }uw;
main( )
{int result;
uw.word=0x1234;
printf(“word value:%04x\n”,uw.word);
printf(“high byte:%02x\n”,uw.byte.high);
printf(“low byte:%02x\n”,uw.byte.low);
uw.byte.low=0x74;
printf(“word value:%04x\n”,uw.word);
result=uw.word+0x2a34;
printf(“the result:%04x\n”,result);
}
6.main()
{char *s2=“I love China!”,**s1=&s2;
char *s3,c,*s4=“w”;
s3=&c;
*s3=‘H’;
s2=s2+2;
printf(“%s\t%c\t%s\t%c\n”,s2,*s3,s4,**s1);
}
四 閱讀下列程式,在 處填入適當內容,使程式完整(20分,每個空2分)

  1. 百馬百擔問題:有100匹馬,馱100擔貨,大馬馱3擔,中馬馱2擔,兩匹小馬馱1擔,問大、中、小馬各多少匹?
    main( )
    {int hb,hm,hl,n=0;
    for(hb=0;hb<=100;hb+= (1) )
    for(hm=0;hm<=100-hb;hm+= (2) )
    {hl=100-hb- (3)
    if(hb/3+hm/2+2* (3) 100)
    {n++;
    printf(“hb=%d,hm=%d,hl=%d\n”,hb/3,hm/2,2*hl); }
    }
    printf(“n=%d\n”,n);
    }
    2.用“起泡法”對輸入的10個字元排序後按從小到大的次序輸出。
    #define N 10
    char str[N];
    main()
    {int i,flag;
    for(flag=1;flag
    1;)
    {scanf("%s",str);
    flag=0;
    printf("\n");
    }
    sort(___(4)___);
    for(i=0;i<N;i++)
    printf("%c",str[i]);
    printf("\n");
    }
    sort(char str[N])
    {int i,j;
    char t;
    for(j=1;j<N;j++)
    for(i=0;(i<N-j)&&(str[i]!=’\0’);i++)
    if(str[i]>str[i+1])
    {t=str[i];
    (5);
    (6);
    }
    }
    3.以下程式是一個函式,功能是求二階矩陣(m行n列矩陣)的所有靠外側的各元素值之和。(本程式中二階矩陣用一維陣列來表示。)
    例如,矩陣為:
    3 0 0 3
    2 5 7 3
    1 0 4 2
    則所有靠外側的各元素值之和為3+0+0+3+2+3+1+0+4+2=18。
    add(int m,int n,int arr[])
    {int i,j,sum=0;
    for(i=0;i<m;i=i+m-1)
    for(j=0;j<n;j++)
    sum=sum+ (7)
    for(j=0;j<n;j=j+n-1)
    for(i=1; (8) i++)
    sum=sum+arr[i*n+j];
    return(sum);
    }
    4.用指標作函式引數,程式設計序求一維陣列中的最大和最小的元素值。
    #define N 10
    main()
    {void maxmin(int arr[],int *pt1,int *pt2,int n);
    int array[N]={10,7,19,29,4,0,7,35,-16,21},*p1,*p2,a,b;
    p1=&a;
    p2=&b;
    maxmin(array,p1,p2,N);
    printf(“max=%d,min=%d”,a,b);
    }
    void maxmin(int arr[],int *pt1,int *pt2,int n)
    {int i;
    *pt1=*pt2=arr[0];
    for(i=1;i<n;i++)
    {if(arr[i]>*pt1)
    (9)
    if(arr[i]<*pt2)
    (10)
    }
    }

答案(二)
一 選擇題(24分,每小題2分)
1.( B ) 2.( C ) 3.( B ) 4.( D )5.( D ) 6.( A ) 7.( D ) 8.( A ) 9.( D ) 10.( B ) 11.( C ) 12.( D )二 判斷對錯,對的劃“√”,錯的劃“×”(20分,每小題2分)
1.( × ) 2.( √ ) 3.( √ )
4.( × ) 5.( × ) 6.( √ )
7.( √ ) 8.( × ) 9.( √ )
10.( √ )
三 寫出下列程式的執行結果(36分,每小題6分)

  1. s=20
  2. x=35 y=-4 s=-29
  3. 60,50,40,30,20,10,
  4. e C pr*am
  5. word value:1234
  6. love China! H w l
    high byte:12
    low byte:34
    word value:1274
    the result:3ca8
    四 閱讀下列程式,在 處填入適當內容,使程式完整(20分,每個空2分)
  7. (1) 3 (2) 2 (3)hm hl
  8. (4) str (5) str[i]=str[i+1] (6) str[i+1]=t
  9. (7) arr[in+j](或者arr[i10+j])
    (8) i<m-1(或者i<=m-2)
  10. (9) *ptr1=arr[i] (10) *ptr2=arr[i]

答案(一)
一 選擇題(7分,每小題0.5分)

  1. B 2. C 3. B 4. B 5. C
  2. A 7. B 8. A 9. A 10. C
  3. A 12. A 13. B 14. D
    二 判斷對錯,對的劃“√”,錯的劃“×”(5分,每小題0.5分)
    1.× 2.× 3.√ 4.√ 5.×
    6.× 7.× 8.× 9.√ 10.√
    四 閱讀下列程式,在 處填入適當內容,使程式完整(8分,每個空1分)
    1.(1)int array[3][4](int array[][4])
    (2)return(max)
    (3)scanf(“%d”,&a[i][j])
    2.(4)*p
    (5)px=&x(py=&y)
    (6)py=&y(px=&x)
    3.(7)
    (8)

相關文章