本文目錄一覽:
- 1、C語言簡單試題大家幫忙做一下!
- 2、C語言的一些試題
- 3、C語言期末考試試題(譚浩強版)
- 4、就那個 計算機二級 C語言的 給我發過來 我選你最佳答案 我急著想用呢
- 5、2009年上半年全國計算機等級考試二級C語言筆試試題及答案
C語言簡單試題大家幫忙做一下!
C.C.?.B.A.D.B.C.D.C.B.B.D.B.C
第三題是不是寫錯了!啥意思啊?鬱悶~
C語言的一些試題
1.a
a=7/2(=3)
4.c
看一下scanf的定義
5.c
“222”是字元串
6.a
沒有轉義
8.b
‘\0’是字元串結束標誌
9.b
試過了,沒想通
10.d
沒有理由
11.c
邏輯與
12.b
y=*a就是y=a
13.b
++在後面
14.a
++a不影響a的地址(vc下不能編譯)
15.c
先++x,x為6,(++x==y)成立,又++x為7
C語言期末考試試題(譚浩強版)
C語言期末考試試題
2008年04月12日 星期六 00:22
一 選擇題(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=52;
A 125,6,31,1
B 125,6,1,20
C 125,6.666666,31,20
D 125.534,6.666666,2,20
4.設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;i68;i++)
{
c=i+32;
switch(c)
{
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( )
{
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;i3;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; //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;i6;i++)
printf(「%d,」,a[i]);
printf(「\n」);
}
invert(int s[ ],int i,int j) //倒置
{
int t;
if(ij)
{
invert(s,i+1,j-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(c)
{
case ‘g’: ++i; break; //由於++i,跳過了g後面的1個字母
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];
void main()
{
int i,flag;
for(flag=1;flag==1;)
{
scanf(“%s”,str);
flag=0;
printf(“\n”);
}
sort(___(4)___);
for(i=0;iN;i++)
{
printf(“%c”,str[i]);
}
printf(“\n”);
}
sort(char str[N]) //冒泡排序
{
int i,j;
char t;
for(j=1;jN;j++)
for(i=0;i10-j;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[])
{
for(i=0;im;i=i+m-1)
for(j=0;jn;j++)
sum=sum+____(7)____;
for(j=0;jn;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;in;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分)
1.(1) 3 (2) 2 (3)hm hl
2.(4) str (5) str[i]=str[i+1] (6) str[i+1]=t
3.(7) arr[i*n+j] (8) im-1
4.(9) *ptr1=arr[i] (10) *ptr2=arr[i]
就那個 計算機二級 C語言的 給我發過來 我選你最佳答案 我急著想用呢
2010年9月全國計算機二級C語言筆試試題:文字版
一、選擇題(每小題2分,共70分)
下列各題A)、B)、C)、D)四個選項中,只有一個選項是正確的。請將正確選項填塗在答題卡相應位置上,答在試卷上不得分。
(1)下列敘述中正確的是
A)線性表的鏈式存儲結構與順序存儲結構所需要的存儲空間是相同的
B)線性表的鏈式存儲結構所需要的存儲空間一般要多於順序存儲結構
C)線性表的鏈式存儲結構所需要的存儲空間一般要少於順序存儲結構
D)上述三種說法都不對
(2)下列敘述中正確的是
A)在棧中,棧中元素隨棧底指針與棧頂指針的變化而動態變化
B)在棧中,棧頂指針不變,棧中元素隨棧底指針的變化而動態變化
C)在棧中,棧底指針不變,棧中元素隨棧頂指針的變化而動態變化
D)上述三種說法都不對
(3)軟體測試的目的是
A)評估軟體可靠性
B)發現並改正程序中的錯誤
C)改正程序中的錯誤
D)發現程序中的錯誤
(4)下面描述中,不屬於軟體危機表現的是
A)軟體過程不規範
B)軟體開發生產率低
C)軟體質量難以控制
D)軟體成本不斷提高
(5)軟體生命周期是指
A)軟體產品從提出、實現、使用維護到停止使用退役的過程
B)軟體從需求分析、設計、實現到測試完成的過程
C)軟體的開發過程
D)軟體的運行維護過程
(6)面向對象方法中,繼承是指
A)一組對象所具有的相似性質
B)一個對象具有另一個對象的性質
C)各對象之間的共同性質
D)類之間共享屬性和操作的機制
(7)層次型、網狀型和關係型資料庫劃分原則是
A)記錄長度
B)文件的大小
C)聯繫的複雜程度
D)數據之間的聯繫方式
(8)一個工作人員可以使用多台計算機,而一台計算機可被多個人使用,則實體工作人員、與實體計算機之間的聯繫是
A)一對一
B)一對多
C)多對多
D)多對一
(9)資料庫設計中反映用戶對數據要求的模式是
A)內模式
B)概念模式
C)外模式
D)設計模式
(10)有三個關係R、S和T如下:
則由關係R和S得到關係T的操作是
A)自然連接
B)交
C)投影
D)並
(11)以下關於結構化程序設計的敘述中正確的是
A)一個結構化程序必須同時由順序、分支、循環三種結構組成
B)結構化程序使用goto語句會很便捷
C)在C語言中,程序的模塊化是利用函數實現的
D)由三種基本結構構成的程序只能解決小規模的問題
(12)以下關於簡單程序設計的步驟和順序的說法中正確的是
A)確定演算法後,整理並寫出文檔,最後進行編碼和上機調試
B)首先確定數據結構,然後確定演算法,再編碼,並上機調試,最後整理文檔
C)先編碼和上機調試,在編碼過程中確定演算法和數據結構,最後整理文檔
D)先寫好文檔,再根據文檔進行編碼和上機調試,最後確定演算法和數據結構
(13)以下敘述中錯誤的是
A) C程序在運行過程中所有計算都以二進位方式進行
B)C程序在運行過程中所有計算都以十進位方式進行
C)所有C程序都需要編譯鏈接無誤後才能運行
D)C程序中整型變數只能存放整數,實型變數只能存放浮點數
(14)有以下定義:int a; long b; double x,y;則以下選項中正確的表達式是
A)a%(int)(x-y)
B)a=x!=y;
C)(a*y)%b
D)y=x+y=x
(15)以下選項中能表示合法常量的是
A)整數:1,200
B)實數:1.5E2.0
C )字元斜杠:『\』
D)字元串:”\007″
(16)表達式a+=a-=a=9的值是
A)9
B)_9
C)18
D)0
(17)若變數已正確定義,在if (W)printf(「%d\n,k」);中,以下不可替代W的是
A)a<>b+c
B)ch=getchar()
C)a==b+c
D)a++
(18)有以下程序
#includestdio.h
main()
{int a=1,b=0;
if(!a) b++;
else if(a==0)if(a)b+=2;
else b+=3;
printf(」%d\n」,b);
}
程序運行後的輸出結果是
A)0
B)1
C)2
D)3
(19)若有定義語句int a, b;double x;則下列選項中沒有錯誤的是
A)switch(x%2) B)switch((int)x/2.0
{case 0: a++; break; {case 0: a++; break;
case 1: b++; break; case 1: b++; break;
default : a++; b++; default : a++; b++;
} }
C)switch((int)x%2) D)switch((int)(x)%2)
{case 0: a++; break; {case 0.0: a++; break;
case 1: b++; break; case 1.0: b++; break;
default : a++; b++; default : a++; b++;
} }
(20)有以下程序
#include stdio.h
main()
{int a=1,b=2;
while(a6){b+=a;a+=2;b%二10;}
printf(」%d,%d\n」,a,b);
}
程序運行後的輸出結果是
A)5,11
B)7,1
C)7,11
D)6,1
(21)有以下程序
#include<stdio.h
main()
{int y=10;
while(y–);
printf(」Y=%d\n」,Y);
}
程序執行後的輸出結果是
A)y=0
B)y= -1
C)y=1
D)while構成無限循環
(22)有以下程序
#include<stdio .h
main()
{char s〔」=」rstuv”;
printf(」%c\n」,*s+2);
}
程序運行後的輸出結果是
A)tuv
B)字元t的ASCII碼值
C)t
D)出錯
(23)有以下程序
#include<stdio.h
#include<string.h
main()
{char x〔〕=」STRING」;
x〔0」=0;x〔1〕=』\0』;x〔2」=』0』;
printf(」%d %d\n」,sizeof(x),strlen(x));
}
程序運行後的輸出結果是
A)6 1
B)7 0
C)6 3
D)7 1
(24)有以下程序
#include<stdio.h
Int f(int x);
main()
{int n=1,m;
m=f(f(f(n)));printf(」%d\n」,m);
}
int f(int x)
{return x*2;}
程序運行後的輸出結果是
A)1
B)2
C)4
D)8
(25)以下程序段完全正確的是
A)int *p; scanf(”%d”,&p);
B)int *p; scanf(「%d」,p);
C)int k, *p=k; scanf(”%d”,p);
D)int k, *p:; *p= k; scanf(「%d」,p);
(26)有定義語句:int *p[4];以下選項中與此語句等價的是
A)int p[4];
B)int **p;
C)int *(p「4」);
D)int (*p)「4」;
(27)下列定義數組的語句中,正確的是
A)int N=10; B)#define N 10
int x[N]; int x[N];
C)int x[0..10〕; D)int x〔〕;
(28)若要定義一個具有5個元素的整型數組,以下錯誤的定義語句是
A)int a[5]={0};
B)int b[]={0,0,0,0,0};
C)int c[2+3];
D)int i=5,d[i];
(29)有以下程序
#include<stdio.h
void f(int *p);
main()
{int a〔5〕={1,2,3,4,5},*r=a;
f(r);printf(」%d\n」;*r);
}
void f(int *p)
{p=p+3;printf(」%d,」,*p);}
程序運行後的輸出結果是
A)1,4
B)4,4
C)3,1
D)4,1
(30)有以下程序(函數fun只對下標為偶數的元素進行操作)
# include<stdio.h
void fun(int*a;int n)
{int i、j、k、t;
for (i=0;i<n一1;1+=2)
{k=i;『
for(j=i;jn;j+=2)if(a〔j〕a〔k])k=j;
t=a〔i];a〔i]=a〔k];a〔k]=t;
}
}
main()
{int aa「10」={1、2、3、4、5、6、7},i;
fun(aa、7);
for(i=0,i7; i++)printf(」%d,」,aa〔i〕));
printf(」\n」);
}
程序運行後的輸出結果是
A)7,2,5,4,3,6,1
B)1,6,3,4,5,2,7
C)7,6,5,4,3,2,1
D)1,7,3,5,6;2,1
(31)下列選項中,能夠滿足「若字元串s1等於字元串s2,則執行ST”要求的是
A)if(strcmp(s2,s1)==0)ST;
B)if(sl==s2)ST;
C)if(strcpy(s l ,s2)==1)ST;
D)if(sl-s2==0)ST;
(32)以下不能將s所指字元串正確複製到t所指存儲空間的是
A)while(*t=*s){t++;s++;}
B)for(i=0;t[i]=s[i〕;i++);
C)do{*t++=*s++;}while(*s);
D)for(i=0,j=0;t[i++]=s[j++];);
(33)有以下程序( strcat函數用以連接兩個字元串)
#include<stdio.h
#include<string .h
main()
{char a〔20〕=」ABCD\OEFG\0」,b〔〕=」IJK」;
strcat(a,b);printf(」%s\n」,a);
}
程序運行後的輸出結果是
A)ABCDE\OFG\OIJK
B)ABCDIJK
C)IJK
D)EFGIJK
(34)有以下程序,程序中庫函數islower (ch)用以判斷ch中的字母是否為小寫字母
#include<stdio.h
#include<ctype.h>
void fun(char*p)
{int i=0;
while (p[i〕)
{if(p[i]==』 』&& islower(p「i-1」))p[i-1]=p[i-1]-『a』+『A』;
i++;
}
}
main()
{char s1〔100〕=」ab cd EFG!」;
fun(s1); printf(」%s\n」,s1);
}
程序運行後的輸出結果是
A)ab cd EFG!
B)Ab Cd EFg!
C)aB cD EFG!
D)ab cd EFg!
(35)有以下程序
#include<stdio.h
void fun(int x)
{if(x/2>1)fun(x/2);
printf(」%d」,x);
}
main()
{fun(7);printf(」\n」);}
程序運行後的輸出結果是
A)1 3 7
B)7 3 1
C)7 3
D)3 7
(36)有以下程序
#include<stdio.h>
int fun()
{static int x=1;
x+=1;return x;
}
main()
{int i;s=1;
for(i=1;i=5;i++)s+=fun();
printf(」%d\n」,s);
}
程序運行後的輸出結果是
A)11
B)21
C)6
D)120
(37)有以下程序
#inctude<stdio.h>
#include<stdlib.h>
Main()
{int *a,*b,*c;
a=b=c=(int*)malloc(sizeof(int));
*a=1;*b=2,*c=3;
a=b;
printf(「%d,%d,%d\n」,*a,*b,*c);
}
程序運行後的輸出結果是
A)3,3,3 B)2,2,3 C)1,2,3 D)1,1,3
(38)有以下程序
#include<stdio.h
main()
{int s,t,A=10;double B=6;
s=sizeof(A);t=sizeof(B);
printf(「%d,%d\n」,s,t);
}
在VC6平台上編譯運行,程序運行後的輸出結果是
A)2,4 B)4,4 C)4,8 D)10,6
(39)若有以下語句
Typedef struct S
{int g; char h;}T;
以下敘述中正確的是
A)可用S定義結構體變數
B)可用T定義結構體變數
C)S是struct類型的變數
D)T是struct S類型的變數
(40)有以下程序
#include<stdio.h
main()
{short c=124;
c=c_______;
printf(「%d\n」、C);
}
若要使程序的運行結果為248,應在下劃線處填入的是
A)2 B)|248 C)&0248 D)I
二、填空題(每空2分,共30分)
請將每空的正確答案寫在答題卡【1】至【15】序號的橫線上,答在試卷上不得分。
(1)一個棧的初始狀態為空。首先將元素5,4,3,2,1依次入棧,然後退棧一次,再將元素 A,B,C,D依次入棧,之後將所有元素全部退棧,則所有元素退棧(包括中間退棧的元素)的順序為【1】
(2)在長度為n的線性表中,尋找最大項至少需要比較【2】次。
(3)一棵二叉樹有10個度為1的結點,7個度為2的結點,則該二叉樹共有【3】個結點。
(4)僅由順序、選擇(分支)和重複(循環)結構構成的程序是【4】程序。
(5)資料庫設計的四個階段是:需求分析,概念設計,邏輯設計【5】。
(6)以下程序運行後的輸出結果是【6】。
#include<stdio.h
main()
{int a=200,b=010;
printf(」%d%d\n」,a,b);
}
(7)有以下程序
#include<stdio.h
main()
{int x,Y;
scanf(」%2d%ld」,&x,&y);printf(」%d\n」,x+y);
}
程序運行時輸入:1234567程序的運行結果是【7】。
(8)在C語言中,當表達式值為0時表示邏輯值「假」,當表達式值為【8】時表示邏輯值「真」。
(9)有以下程序
#include<stdio.h
main()
{int i,n[]={0,0,0,0,0};
for (i=1;i=4;i++)
{n[i]=n[i-1]*3+1; printf(」%d “,n[i]);}
}
程序運行後的輸出結果是【9】。
(10)以下fun函數的功能是:找出具有N個元素的一維數組中的最小值,並作為函數值返回。請填空。(設N已定義)
int fun(int x〔N〕)
{int i,k=0;
for(i=0;iN;I++)
if(x〔i〕
return x〔k〕;
}
(11)有以下程序
#include<stdio.h
int*f(int *p,int*q);
main()
{int m=1,n=2,*r=m;
r=f(r,&n);printf(」%d\n」,*r);
}
int*f(int *p,int*q)
{return(*p*q)?p:q;}
程序運行後的輸出結果是【11】
(12)以下fun函數的功能是在N行M列的整形二維數組中,選出一個最大值作為函數值返回,請填空。(設M,. N已定義)
int fun(int a〔N〕[M))
{int i,j,row=0,col=0;
for(i=0;iN;I++)
for(j=0;j
if(a〔i〕〔j〕>a〔row〕〔col〕){row=i;col=j;}
return(【12】):
}
(13)有以下程序
#include<stdio.h
main()
{int n[2],i,j;
for(i=0;i2;i++)n[i]=0;
for(i=0;i<2;i++)
for(j=0;j2;j++)n〔j〕=n「i」+1;
printf(」%d\n」,n[1]);
}
程序運行後的輸出結果是【13】
(14)以下程序的功能是:藉助指針變數找出數組元素中最大值所在的位置並輸出該最大值。請在輸出語句中填寫代表最大值的輸出項。
#include<stdio.h
main()
{int a〔10〕,*p,*s;
for(p=a;p-a10;p++)scanf(」%d」,p);
for(p=a,s=a;p-a10;p++)if(*p*s)S=P;
printf(”max=%d\n」,【14】);
}
(15)以下程序打開新文件f.txt,並調用字元輸出函數將a數組中的字元寫入其中,請填空。
#include<stdio.h
main()
{【15】*fp;
char a〔5〕={』1』,』2』,』3』,』4』,』5』},i;
fp=fopen(」f .txt」,」w」);
for(i=0;i5;i++)fputc(a[i],fp);
fclose(fp);
}
2009年上半年全國計算機等級考試二級C語言筆試試題及答案
一、選擇題(每題2分,共計70分)
1.(1)下列敘述中正確的是
A)棧是先進先出的線性表
B)隊列是”先進後出”的線性表
C)循環隊列是非線性結構
D)有序線性表即可以採用順序存儲結構,也可以採用鏈式存儲結構
2.
(2)支持子程序調用的數據結構是
A)棧
B)樹
C)隊列
D)二叉樹
3.
(3)某二叉樹有5個讀為2的結點,則該二叉樹中的葉子結點數是
A)10
B)8
C)6
D)4
4.
(4)下列排序方法中,最壞情況下比較次數最少的是
A)冒泡排序
B)簡單選擇排序
C)直接插入排序
D)堆排序
(5)軟體按功能可以分為:應用軟體、系統軟體和支撐軟體(或工具軟體)。下列
屬於應用軟體的是
A)編譯程序
B)操作系統
C)教務管理系統
D)彙編程序
6.
(6)下面敘述中錯誤的是
A)軟體測試的目的是發現錯誤並改正錯誤
B)對被調試程序進行”錯誤定位”是程序調試的必要步驟
C)程序調試也成為Debug
D)軟體測試應嚴格執行測試計劃,排除測試的隨意性
7.
(7)耦合性和內聚性是對模塊獨立性度量的兩個標準。下列敘述中正確的是
A)提高耦合性降低內聚性有利於提高模塊的獨立性
B)降低耦合性提高內聚性有利於提高模塊的獨立性
C)耦合性是指一個模塊內部各個元素間彼此結合的緊密程度
D)內聚性是指模塊間互相連接的緊密程度
8.
(8)資料庫應用系統中的核心問題是
A)資料庫設計
B)資料庫系統設計
C)資料庫維護
D)資料庫管理員培訓
9.
(9)有兩個關係R,S如下:
由關係R通過運算得到關係S,則所使用的運算為
A)選擇
B)投影
C)插入
D)連接
10.
(10)將E-R圖轉換為關係模式時,實體和聯繫都可以表示為
A)屬性
B)鍵
C)關係
D)域
11.(11)一下選項中合法的標識符是
A)1_1
B)1-1
C)_11
D)1_ _
12.
(12)若函數中有定義語句:int k;,則
A)系統將自動給k賦初值0
B)這是k中的值無定義
C)系統將自動給k賦初值-1
D)這時k中無任何值
13.
(13)一下選項中,能用作數據常量的是
A)o115
B)0118
C)1.5e1.5
D)115L
14.
(14)設有定義:int x=2;,一下表達式中,值不為6的是
A)x*=x+1
B)X++,2*x
C)x*=(1+x)
D)2*x,x+=2
15.
(15)程序段:int x=12; double y=3.141593;printf(“%d%8.6f”,x,y);的輸出結果是
A)123.141593
B)12 3.141593
C)12,3.141593
D)123.1415930
16.
(16)若有定義語句:double x,y,*px,*py;執行了px=x;py=y;之後,正確的輸入語句是
A)scanf(“%f%f”,x,y);
B)scanf(“%f%f” x,y);
C)scanf(“%lf%le”,px,py);
D)scanf(“%lf%lf”,x,y);
17.
(17)一下是if語句的基本形式:
if(表達式) 語句
其中”表達式”
A)必須是邏輯表達式
B)必須是關係表達式
C)必須是邏輯表達式或關係表達式
D)可以是任意合法的表達式
18.
(18)有以下程序
#include stdio.h
main()
{ int x;
scanf(“%d”,x);
if(x=3) ; else
if(x!=10) printf(“%d\n”,x);
}
程序運行時,輸入的值在哪個範圍才會有輸出結果
A)不等於10的整數
B)大於3且不等於10的整數
C)大於3或等於10的整數
D)小於3的整數
19.
(19)有以下程序
#include stdio.h
main()
{ int a=1,b=2,c=3,d=0;
if (a==1 b++==2)
if (b!=2||c–!=3)
printf(“%d,%d,%d\n”,a,b,c);
else printf(“%d,%d,%d\n”,a,b,c);
else printf(“%d,%d,%d\n”,a,b,c);
}
程序運行後輸出結果是
A)1,2,3
B)1,3,2
C)1,3,3
D)3,2,1
20.
(20)一下程序段中的變數已正確定義
for(i=0;i4;i++,j++)
for(k=1;k3;k++); printf(“*”);
程序段的輸出結果是
A)********
B)****
C)**
D)*
21.(21)有以下程序
#include stdio.h
main()
{ char *s={“ABC”};
do
{ printf(“%d”,*s%10);s++;
}
while (*s);
}
注意:字母A的ASCII碼值為65。程序運行後的輸出結果是
A)5670
B)656667
C)567
D)ABC
22.
(22)設變數已正確定義,以下不能統計出一行中輸入字元個數(不包含回車符)的程序段是
A)n=0;while((ch=getchar())!=~\n~)n++;
B)n=0;while(getchar()!=~\n~)n++;
C)for(n=0;getchar()!=~\n~;n++);
D)n=0;for(ch=getchar();ch!=~\n~;n++);
23.
(23)有以下程序
#include stdio.h
main()
{ int a1,a2; char c1,c2;
scanf(“%d%c%d%c”,a1,c1,a2,c2);
printf(“%d,%c,%d,%c”,a1,c1,a2,c2);
}
若通過鍵盤輸入,使得a1的值為12,a2的值為34,c1的值為字元a,c2的值為字元b,
程序輸出結果是:12,a,34,b 則正確的輸入格式是(以下_代表空格,CR代表回車)
A)12a34bCR
B)12_a_34_bCR
C)12,a,34,bCR
D)12_a34_bCR
24.
(24)有以下程序
#include stdio.h
int f(int x,int y)
{ return ((y-x)*x);}
main()
{ int a=3,b=4,c=5,d;
d=f(f(a,b),f(a,c));
printf(“%d\n”,d);
}
程序運行後的輸出結果是
A)10
B)9
C)8
D)7
25.
(25)有以下程序
#include stdio.h
void fun(char *s)
{ while(*s)
{ if (*s%2==0) printf(“%c”,*s);
s++;
}
}
main()
{ char a[]={“good”};
fun(a); printf(“\n”);
}
注意:字母a的ASCII碼值為97,程序運行後的輸出結果是
A)d
B)go
C)god
D)good
26.
(26)有以下程序
#include stdio.h
void fun(int *a,int *b)
{ int *c;
c=a;a=b;b=c;
}
main()
{ int x=3,y=5,*p=x,*q=y;
fun(p,q); printf(“%d,%d,”,*p,*q);
fun(x,y);printf(“%d,%d\n”,*p,*q);
}
程序運行後輸出的結果是
A)3,5,5,3
B)3,5,3,5
C)5,3,3,5
D)5,3,5,3
27.
(27)有以下程序
#include stdio.h
void f(int *p,int *q);
main()
{ int m=1,n=2,*r=m;
f(r,n); printf(“%d,%d”,m,n);
}
void f(int *p,int *q)
{p=p+1;*q=*q+1;}
程序運行後的輸出結果是
A)1,3
B)2,3
C)1,4
D)1,2
28.
(28)以下函數按每行8個輸出數組中的數據
#include stdio.h
void fun(int *w,int n)
{ int i;
for(i=0;in;i++)
{ ____________
printf(“%d “,w[i]);
}
printf(“\n”);
}
下劃線出應填入的語句是
A)if(i/8==0) printf(“\n”);
B)if(i/8==0) continue;
C)if(i%8==0) printf(“\n”);
D)if(i%8==0) continue;
29.
(29)若有以下定義
int x[10],*pt=x;
則對數組元素的正確引用是
A)*x[10]
B)*(x+3)
C)*(pt+10)
D)pt+3
30.
(30)設有定義:char s[81];int i=0;,以下不能將一行(不超過80個字元)帶有空格
的字元串正確讀入的語句或語句組是
A)gets(s);
B)while((s[i++]=getchar())!=~\n~);s[i]=~\0~;
C)scanf(“%s”,s);
D)do{scanf(“%c”,s[i]);}while(s[i++]!=~\n~);s[i]=~\0~;
31.
(31)有以下程序
#include stdio.h
main()
{ char *a[]={“abcd”,”ef”,”gh”,”ijk”};int i;
for(i=0;i4;i++) printf(“%c”,*a[i]);
}
程序運行後的輸出結果是
A)aegi
B)dfhk
C)dfhk
D)abcdefghijk
32.
(32)以下選項中正確的語句組是
A)char s[];s=”BOOK!”;
B)char *s;s={“BOOK!”};
C)char s[10];s=”BOOK!”;
D)char *s;s=”BOOK!”;
33.
(33)有以下程序
#include stdio.h
int fun(int x,int y)
{ if(x==y) return (x);
else return((x+y)/2);
}
main()
{ int a=4,b=5,c=6;
printf(“%d\n”,fun(2*a,fun(b,c)));
}
程序運行後的輸出結果是
A)3
B)6
C)8
D)12
34.
(34)設函數中有整型變數n,為保證其在未賦初值的情況下初值為0,應該選擇的存儲類別是
A)auto
B)register
C)static
D)auto 或register
35.
(35)有以下程序
#include stdio.h
int b=2;
int fun(int *k)
{ b=*k+b;return (b);}
main()
{ int a[10]={1,2,3,4,5,6,7,8},i;
for(i=2;i4;i++) {b=fun(a[i])+b; printf(“%d “,b);}
printf(“\n”);
}
程序運行後的輸出結果是
A)10 12
B)8 10
C)10 28
D)10 16
36.
(36)有以下程序
#include stdio.h
#define PT 3.5 ;
#define S(x) PT*x*x ;
main()
{ int a=1,b=2 ; printf(“%4.1f\n”,S(a+b));}
程序運行後的輸出結果是
A)14.0
B)31.5
C)7.5
D)程序有錯無輸出結果
37.
(37) 有以下程序
#include stdio.h
struct ord
{ int x,y; } dt[2]={1,2,3,4};
main()
{ struct ord *p=dt;
printf(“%d,”,++p-x); printf(“%d\n”,++p-y);
}
程序的運行結果是
A)1,2
B)2,3
C)3,4
D)4,1
38.
(38)設有宏定義:#define IsDIV(k,n) ((k%n==1)?1:0)且變數m已正確定義並賦值,
則宏調用:IsDIV(m,5)IsDIV(m,7)為真時所要表達的是
A)判斷m是否能被5或者7整除
B)判斷m是否能被5和7整除
C)判斷m被5或者7整除是否餘1
D)判斷m被5和7整除是否都餘1
39.
(39)有以下程序
#include stdio.h
main()
{ int a=5,b=1,t;
t=(a2)|b; printf(“%d\n”,t);
}
程序運行後的輸出結果是
A)21
B)11
C)6
D)1
40.
(40)有以下程序
#include stdio.h
main()
{ FILE *f;
f=fopen(“filea.txt”,”w”);
fprintf(f,”abc”);
fclose(f);
}
若文本文件filea.txt中原有內容為:hello,則運行以上程序後,文件filea.txt的內容為
A)helloabc
B)abclo
C)abc
D)abchello
2009年3月二級C語言程序設答案
選擇題:
1-10: DACDC ABABC
11-20:CBDDA CDBCB
21-30:CDABA BACBC
31-40:ADBCC CBDAC
填空題:
(1)19
(2)白盒
(3)順序結構
(4)資料庫管理系統(DBMS)
(5)菱形
(6)4
(7)”x/y=%d”
(8)能
(9)s=0
(10)1AbCeDf2dF
(11)7777654321
(12)max(int a,int b)
(13)NULL
(14)1001,ChangRong,1098.0
(15)p=p—next
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/288583.html