當前位置:首頁 » 編程語言 » c語言歷年真題及答案

c語言歷年真題及答案

發布時間: 2025-05-24 11:01:15

❶ 2011年三月全國計算機二級c真題及答案

2011年3月計算機二級c真題

一、 選擇題

(1)下列關於棧敘述正確的是

A)棧頂元素最先能被刪除

B)棧頂元素最後才能被刪除

C)棧底元素永遠不能被刪除

D)以上三種說法都不對

(2)下列敘述中正確的是

A)有一個以上根結點的數據結構不一定是非線性結構

B)只有一個根結點的數據結構不一定是線性結構

C)循環鏈表是非線性結構

D)雙向鏈表是非線性結構

(3)某二叉樹共有7個結點,其中葉子結點只有1個,則該二叉樹的深度為(假設根結點在第1層)

A)3 B)4 C)6 D)7

(4)在軟體開發中,需求分析階段產生的主要文檔是

A)軟體集成測試計劃 B)軟體詳細設計說明書

C)用戶手冊 D)軟體需求規格說明書

(5)結構化程序所要求的基本結構不包括

A)順序結構 B)GOTO跳轉

C)選擇(分支)結構 D)重復(循環)結構

(6)下面描述中錯誤的是

A)系統總體結構圖支持軟體系統的詳細設計

B)軟體設計是將軟體需求轉換為軟體表示的過程

C)數據結構與資料庫設計是軟體設計的任務之一

D)PAD圖是軟體詳細設計的表示工具

(7)負責資料庫中查詢操作的資料庫語言是

A)數據定義語言

B)數據管理語言

C)數據操縱語言

D)數據控制語言

(8)一個教師可講授多門課程,一門課程可由多個教師講授。則實體教師和課程間的聯系是

A)1:1聯系 B)1:m聯系

C)m:1聯系 D)m:n聯系

(9)有三個關系R、S和T如下:

則由關系R和S得到關系T的操作是

A)自然連接 B)交 C)除 D)並

(10)定義無符號整數類為UInt,下面可以作為類UInt實例化值的是

A)-369 B)369 C)0.369 D)整數集合{1,2,3,4,5}

(11)計算機高級語言程序的運行方法有編譯執行和解釋執行兩種,以下敘述中正確的是

A)c語言程序僅可以編譯執行

B)C語言程序僅可以解釋執行

C)C語言程序既可以編譯執行又可以解釋執行

D)以上說法都不對

(12)以下敘述中錯誤的是

A)C語言的可執行程序是由一系列機器指令構成的

B)用C語言編寫的源程序不能直接在計算機上運行

C)通過編譯得到的二進制目標程序需要連接才可以運行

D)在沒有安裝C語言集成開發環境的機器上不能運行C源程序生成的.exe文件

> (13)以下選項中不能用作C程序合法常量的是

A)1,234 B)'123'

C)123 D)"\x7G"

(14)以下選項中可用作C程序合法實數的是

A).1e0 B)3.0e0.2

C)E9 D)9.12E

(15)若有定義語句:int a=3,b=2,c=1;,以下選項中錯誤的賦值表達式是

A)a=(b=4)=3; B)a=b=c+1;

C)a=(b=4)+c; D)a=1+(b=c=4);

(16)有以下程序段

char name[20];

int num;

scanf("name=%s num=%d",name;&num);

當執行上述程序段,並從鍵盤輸入:name=Lili num=1001<回車>後,name的值為

A)Lili

B)name=Lili

C)Lili num=

D)name=Lili num=1001

(17)if語句的基本形式是:if(表達式)語句,以下關於「表達式」值的敘述中正確的是

A)必須是邏輯值 B)必須是整數值

C)必須是正數 D)可以是任意合法的數值

(18)有以下程序

#include

main()

{ int x=011;

printf("%d\n",++x);

}

程序運行後的輸出結果是

A)12 B)11 C)10 D)9

(19)有以下程序

#include

main()

{ int s;

scanf("%d",&s);

while(s>0)

{ switch(s)

{ case1:printf("%d",s+5);

case2:printf("%d",s+4); break;

case3:printf("%d",s+3);

default:printf("%d",s+1);break;

}

scanf("%d",&s);

}

}

運行時,若輸入1 2 3 4 5 0<回車>,則輸出結果是

A)6566456 B)66656 C)66666 D)6666656

(20)有以下程序段

int i,n;

for(i=0;i<8;i++)

{ n=rand()%5;

switch (n)

{ case 1:

case 3:printf("%d\n",n); break;

case 2:

case 4:printf("%d\n",n); continue;

case 0:exit(0);

}

printf("%d\n",n);

}

以下關於程序段執行情況的敘述,正確的是

A)for循環語句固定執行8次

B)當產生的隨機數n為4時結束循環操作

C)當產生的隨機數n為1和2時不做任何操作

D)當產生的隨機數n為0時結束程序運行

(21)有以下程序

#include

main()

{ char s[]="012xy\08s34f4w2";

int i,n=0;

for(i=0;s[i]!=0;i++)

if(s[i]>='0'&&s[i]<='9') n++;

printf("%d\n",n);

}

程序運行後的輸出結果是

A)0 B)3 C)7 D)8

(22)若i和k都是int類型變數,有以下for語句

for(i=0,k=-1;k=1;k++) printf("*****\n");

下面關於語句執行情況的敘述中正確的是

A)循環體執行兩次

B)循環體執行一次

C)循環體一次也不執行

D)構成無限循環

(23)有以下程序

#include

main()

{ char b,c; int i;

b='a'; c='A';

for(i=0;i<6;i++)

{ if(i%2) putchar(i+b);

else putchar(i+c);

} printf("\n");

}

程序運行後的輸出結果是

A)ABCDEF B)AbCdEf C)aBcDeF D)abcdef

(24)設有定義:double x[10],*p=x;,以下能給數組x下標為6的元素讀入數據的正確語句是

A)scanf("%f",&x[6]); B)scanf("%lf",*(x+6));

C)scanf("%lf",p+6); D)scanf("%lf",p[6]);

(25)有以下程序(說明:字母A的ASCII碼值是65)

#include

void fun(char *s)

{ while(*s)

{ if(*s%2) printf("%c",*s);

s++;

}

}

main()

{ char a[]="BYTE";

fun(a); printf("\n");

}

程序運行後的輸出結果是

A)BY B)BT C)YT D) YE

(26)有以下程序段

#include

main()

{ …

while( getchar()
!='\n');



}

以下敘述中正確的是

A)此while語句將無限循環

B) getchar()不可以出現在while語句的條件表達式中

C)當執行此while語句時,只有按回車鍵程序才能繼續執行

D)當執行此while語句時,按任意鍵程序就能繼續執行

(27)有以下程序

#include

main()

{ int x=1,y=0;

if(!x) y++;

else if(x==0)

if (x) y+=2;

else y+=3;

printf("%d\n",y);

}

程序運行後的輸出結果是

A)3 B)2 C)1 D) 0

(28)若有定義語句:char s[3][10],(*k)[3],*p;,則以下賦值語句正確的是

A)p=s; B)p=k; C)p=s[0]; D)k=s;

(29)有以下程序

#include

void fun(char *c)

{ while(*c)

{ if(*c>='a'&&*c<='z') *c=*c-('a'-'A');

c++;

}

}

main()

{ char s[81];

gets(s); fun(s); puts(s):

}

當執行程序時從鍵盤上輸入Hello Beijing<回車>,則程序的輸出結果是

A)hello beijing B)Hello Beijing C)HELLO BEIJING D)hELLO Beijing

(30)以下函數的功能是:通過鍵盤輸入數據,為數組中的所有元素賦值。

#include

#define N 10

void fun(int x[N])

{ int i=0;

while(i

}

在程序中下劃線處應填入的是

A)x+i B)&x[i+1]

C)x+(i++) D)&x[++i]

(31)有以下程序

#include

main()

{ char a[30],b[30];

scanf("%s",a);

gets(b);

printf("%s\n %s\n",a,b);

}

程序運行時若輸入:

how are you? I am fine<回車>

則輸出結果是

A)how are you? B)how

I am fine are you? I am fine

C)how are you? I am fine

D)row are you?

(32)設有如下函數定義

int fun(int k)

{ if (k<1) return 0;

else if(k==1) return 1;

else return fun(k-1)+1;

}

若執行調用語句:n=fun(3);,則函數fun總共被調用的次數是

A)2 B)3 C)4 D)5

(33)有以下程序

#include

int fun (int x,int y)

{ if (x!=y) return ((x+y);2);

else return (x);

}

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)有以下程序

#include

int fun()

{ static int x=1;

x*=2;

return x;

}

main()

{ int i,s=1;

for(i=1;i<=3;i++) s*=fun();

printf("%d\n",s);

}

程序運行後的輸出結果是

A)0 B)10 C)30 D)64

(35)有以下程序

#include

#define S(x) 4*(x)*x+1

main()

{ int k=5,j=2;

printf("%d\n",S(k+j));

}

程序運行後的輸出結果是

A)197 B)143 C)33 D)28

(36)設有定義:struct {char mark[12];int num1;double num2;} t1,t2;,若變數均已正確賦初值,則以下語句中錯誤的是

A)t1=t2; B)t2.num1=t1.num1;

C)t2.mark=t1.mark; D)t2.num2=t1.num2;

(37)有以下程序

#include

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)4,1 C)3,4 D)2,3

(38)有以下程序

#i
nclude

struct S

{ int a,b;}data[2]={10,100,20,200};

main()

{ struct S p=data[1];

printf("%d\n",++(p.a));

}

程序運行後的輸出結果是

A)10 B)11 C)20 D)21

(39)有以下程序

#include

main()

{ unsigned char a=8,c;

c=a>>3;

printf("%d\n",c);

}

程序運行後的輸出結果是

A)32 B)16 C)1 D)0

(40)設fp已定義,執行語句fp=fopen("file","w");後,以下針對文本文件file操作敘述的選項中正確的是

A)寫操作結束後可以從頭開始讀 B)只能寫不能讀

C)可以在原有內容後追加寫 D)可以隨意讀和寫

二、填空題

(1)有序線性表能進行二分查找的前提是該線性表必須是 【1】 存儲的。

(2)一棵二叉樹的中序遍歷結果為DBEAFC,前序遍歷結果為ABDECF,則後序遍歷結果為 【2】 。

(3)對軟體設計的最小單位(模塊或程序單元)進行的測試通常稱為 【3】測試。

(4)實體完整性約束要求關系資料庫中元組的 【4】 屬性值不能為空。

(5)在關系A(S,SN,D)和關系B(D,CN,NM)中,A的主關鍵字是S,B的主關鍵字是D,則稱 【5】是關系A的外碼。

(6)以下程序運行後的輸出結果是 【6】 。

#include

main()

{ int a;

a=(int)((double)(3/2)+0.5+(int)1.99*2);

printf("%d\n",a);

}

(7)有以下程序

#include

main()

{ int x;

scanf("%d",&x);

if(x>15) printf("%d",x-5);

if(x>10) printf("%d",x);

if(x>5) printf("%d\n",x+5);

}

若程序運行時從鍵盤輸入12<回車>,則輸出結果為 【7】 。

(8)有以下程序(說明:字元0的ASCII碼值為48)

#include

main()

{ char c1,c2;

scanf("%d",&c1);

c2=c1+9;

printf("%c%c\n",c1,c2);

}

若程序運行時從鍵盤輸入48<回車>,則輸出結果為 【8】 。

(9)有以下函數

void prt(char ch,int n)

{ int i;

for(i=1;i<=n;i++)

printf(i%6!=0?"%c":"%c\n",ch);

}

執行調用語句prt('*',24);後,函數共輸出了 【9】 行*號。

(10)以下程序運行後的輸出結果是 【10】 。

#include

main()

{ int x=10,y=20,t=0;

if(x==y)t=x;x=y;y=t;

printf("%d %d\n",x,y);

}

(11)己知a所指的數組中有N個元素。函數fun的功能是,將下標k(k>0)開始的後續元素全部向前移動一個位置。請填空。

void fun(int a[N],int k)

{ int i;

for(i=k;i

}

(12)有以下程序,請在 【12】 處填寫正確語句,使程序可正常編譯運行。

#include

【12】 ;

main()

{ double x,y,(*p)();

scanf("%lf%lf",&x,&y);

p=avg;

printf("%f\n",(*p)(x,y));

}

double avg(double a,double b)

{ return((a+b)/2);}

(13)以下程序運行後的輸出結果是 【13】 。

#include

main()

{ int i,n[5]={0};

for(i=1;i<=4;i++)

{ n[i]==n[i-1]*2+1; printf("%d",n[i]); }

printf("\n");

}

(14)以下程序運行後的輸出結果是 【14】 。

#include

#include

#include

main()

{ char *p; int i;

p=(char *)malloc(sizeof(char)*20);

strcpy(p,"welcome");

for(i=6;i>=0;i--) putchar(*(p+i));

printf("\n-"); free(p);

}

(15)以下程序運行後的輸出結果是 【15】 。

#include

main()

{ FILE *fp; int x[6]={1,2,3,4,5,6},i;

fp=fopen("test.dat","wb");

fwrite(x,sizeof(int),3,fp);

rewind(fp);

fread(x,sizeof(int),3,fp);

for(i=0;i<6;i++) printf("%d",x[i]);

printf("\n");

fclose(fp);

}

2011年3月計算機二級c答案:
一、選擇題
01-10:ABDDB ACDCB
11-20:ADBAA ADCAD
21-30:BDBCD CDCCC
31-40:BBBDB CDDCB
二、填空題
1.有序 2.DEBFCA 3.單元 4.主 5.D 6.3 7.1217 8.09 9.4 10.20 0
11.i-1 12.double avg(double a, double b); 13.13715 14.emoclew 15.123456

❷ 國二C語言到底考什麼

國家二級C語言的考綱分兩部分:公共基礎知識和C語言。
具體內容如下:
公共基礎知識 考試大綱
◆ 基本要求
1.掌握演算法的基本概念。
2.掌握基本數據結構及其操作。
3.掌握基本排序和查找演算法。
4.掌握逐步求精的結構化程序設計方法。
5.掌握軟體工程的基本方法,具有初步應用相關技術進行軟體開發的能力。
6.掌握資料庫的基本知識,了解關系資料庫的設計。
◆ 考試內容
一、基本數據結構與演算法
1.演算法的基本概念;演算法復雜度的概念和意義(時間復雜度與空間復雜度)。
2.數據結構的定義;數據的邏輯結構與存儲結構;數據結構的圖形表示;線性結構與非線性結構的概念。
3.線性表的定義;線性表的順序存儲結構及其插入與刪除運算。
4.棧和隊列的定義;棧和隊列的順序存儲結構及其基本運算。
5.線性單鏈表、雙向鏈表與循環鏈表的結構及其基本運算。
6.樹的基本概念;二叉樹的定義及其存儲結構;二叉樹的前序、中序和後序遍歷。
7.順序查找與二分法查找演算法;基本排序演算法(交換類排序,選擇類排序,插入類排序)。
二、程序設計基礎
1.程序設計方法與風格。
2.結構化程序設計。
3.面向對象的程序設計方法,對象,方法,屬性及繼承與多態性。
三、軟體工程基礎
1.軟體工程基本概念,軟體生命周期概念,軟體工具與軟體開發環境。
2.結構化分析方法,數據流圖,數據字典,軟體需求規格說明書。
3.結構化設計方法,總體設計與詳細設計。
4.軟體測試的方法,白盒測試與黑盒測試,測試用例設計,軟體測試的實施,單元測試、集成測試和系統測試。
5.程序的調試,靜態調試與動態調試。
四、資料庫設計基礎
1.資料庫的基本概念:資料庫,資料庫管理系統,資料庫系統。
2.數據模型,實體聯系模型及E-R圖,從E-R圖導出關系數據模型。
3.關系代數運算,包括集合運算及選擇、投影、連接運算,資料庫規范化理論。
4.資料庫設計方法和步驟:需求分析、概念設計、邏輯設計和物理設計的相關策略。
◆ 考試方式
公共基礎知識有10道選擇題和5道填空題共三十分

C語言 考試大綱
◆ 基本要求
1.熟悉 Visual C++ 6.0 集成開發環境。
2.掌握結構化程序設計的方法,具有良好的程序設計風格。
3.掌握程序設計中簡單的數據結構和演算法並能閱讀簡單的程序。
4.在 Visual C++ 6.0 集成環境下,能夠編寫簡單的C程序,並具有基本的糾錯和調試程序的能力
◆ 考試內容
一、C語言程序的結構
1.程序的構成,main函數和其他函數。
2.頭文件,數據說明,函數的開始和結束標志以及程序中的注釋。
3.源程序的書寫格式。
4.C語言的風格。
二、數據類型及其運算
1.C的數據類型(基本類型,構造類型,指針類型,無值類型)及其定義方法。
2.C運算符的種類、運算優先順序和結合性。
3.不同類型數據間的轉換與運算。
4.C表達式類型(賦值表達式,算術表達式,關系表達式,邏輯表達式,條件表達式,逗號表達式)和求值規則。
三、基本語句
1.表達式語句,空語句,復合語句。
2.輸入輸出函數的調用,正確輸入數據並正確設計輸出格式。
四、選擇結構程序設計
1.用if語句實現選擇結構。
2.用switch語句實現多分支選擇結構。
3.選擇結構的嵌套。
五、循環結構程序設計
1.for循環結構。
2.while和do-while循環結構。
3.continue語句和break語句。
4.循環的嵌套。
六、數組的定義和引用
1.一維數組和二維數組的定義、初始化和數組元素的引用。
2.字元串與字元數組。
七、函數
1.庫函數的正確調用。
2.函數的定義方法。
3.函數的類型和返回值。
4.形式參數與實在參數,參數值傳遞。
5.函數的正確調用,嵌套調用,遞歸調用。
6.局部變數和全局變數。
7.變數的存儲類別(自動,靜態,寄存器,外部),變數的作用域和生存期。
八、編譯預處理
1.宏定義和調用(不帶參數的宏,帶參數的宏)。
2.「文件包含」處理。
九、指針
1.地址與指針變數的概念,地址運算符與間址運算符。
2.一維、二維數組和字元串的地址以及指向變數、數組、字元串、函數、結構體的指針變數的定義。

❸ 全國計算機等級考試二級C語言考試內容有些什麼

分筆試和上機考:
一、筆試 選擇40題,前10題為公共基礎知識

(1)、填空15題,前5題為公共基礎知識

(2)、只有C部分的前10題(即11~20)每題1分,其餘填空選擇都是2分,滿分100分,時間90分鍾。

二、上機 填空、改錯和程序設計題

(1)填空題一般有2到3個空,需要刪除對應的空後,在刪除的位置填上正確的答案。(30分)

(2)、改錯題的錯誤在/********found******/下面,不要改動其它的地方。(2~3個,30分)。

(3)、然後就是程序設計題啦,40分,考試時間90分鍾,上機考試每題完成後一定記得運行。

(3)c語言歷年真題及答案擴展閱讀

1、熟悉Visual C++6. 0集成開發環境。

2、掌握結構化程序設計的方法,具有良好的程序設計風格。

3、掌握程序設計中簡單的數據結構和演算法並能閱讀簡單的程序。

4、在Visual C++6. 0集成環境下,能夠編寫簡單的C程序,並具有基本的糾錯和調試程序的能力。

❹ 2020計算機二級c語言考試真題

如何獲取計算機C語言考試資料呢?也就是往年的考試真題的資料。

2020C語言考點的話。可以去買未來教育的書考試真題的所有類型裡面都有的,這個我不是很推薦買,看個人需求。2020年的C語言考試真題也在裡面。或者官網上可查詢題目。如果是視頻的話,自己去搜索。如果是軟體的話,我也推薦買個未來教育的,單買個軟體也不貴,需橡晌要的話自己去搜,我只是推薦你們可以買,這個軟體當時我也用過,是挺不錯的。裡面有各個知識點的題目,也有整套的題目,也有答案解析,也有模擬考試的,不過有的功能好像是要另外付費的,你們可以自己去了解一下。以下是其中的部分真題衫伍。

計算機二級C語言考公共基礎知識部分10%,C語言部分90%。參照復習的話,我推薦你們最好去搜一下計算機二級C語言的網課,去看網課,如果說你們不想做筆記的話可以到購買C語言考試筆記的奧。如果你有心准備,二級C語言只需要一個月的時間就可以搞定!當然有基礎的話肯定不需要這么多時間。如果你有基礎的話,我推薦你先去看公共基礎知識的網課用1.5倍速,甚至2倍速,重點是把裡面的知識點理清,靠看網課完全背不下來的,大部分題都是從題庫裡面抽出來的,我們的目的並不是說只為了抽中你會的題目而去刷,而是這就是真題。最後,祝願小或如或夥伴們考試順利。

❺ 求09年3月份全國計算機等級考試二級c語言筆試試題的詳細講解

09年3月全國計算機等級考試二級C筆試真題(附答案)(考試時間90分鍾,滿分100分)一、選擇題(1)下列敘述中正確的是 A) 棧是先進先出(FIFO)的線性表B) 隊列是先進先出(FIFO)的線性表C) 循環隊列是非線性結構D) 有序線性表既可以採用順序存儲結構,也可以採用鏈式存儲結構(2)支持子程序調用的數據結構是 A) 棧 B) 樹 C) 隊列 D)二叉樹(3)某二叉樹有5個度為2的結點,則該二叉樹中的葉子結點數是 A)10 B)8 C)6 D)4(4)下列排序方法中,最壞情況下比較次數最少的是 A)冒泡排序 B)簡單選擇排序 C)直接插入排序 D)堆排序(5)軟體按功能可以分為:應用軟體、系統軟體和支撐軟體(或工具軟體)。下面屬於應用軟體的是 A)編譯軟體 B)操作系統 C)教務管理系統 D)匯編程序(6)下面敘述中錯誤的是A)軟體測試的目的是發現錯誤並改正錯誤B)對被調試的程序進行「錯誤定位」是程序調試的必要步驟C)程序調試通常也稱為DebugD)軟體測試應嚴格執行測試計劃,排除測試的隨意性(7)耦合性和內聚性是對模塊獨立性度量的兩個標准。下列敘述中正確的是 A)提高耦合性降低內聚性有利於提高模塊的獨立性B)降低耦合性提高內聚性有利於提高模塊的獨立性C)耦合性是指一個模塊內部各個元素間彼此結合的緊密程度D)內聚性是指模塊間互相連接的緊密程度(8)資料庫應用系統中的核心問題是A)資料庫設計 B)資料庫系統設計C)資料庫維護 D) 資料庫管理員培訓(9)有兩個關系R,S如下:R SA B C A Ba 3 2 a 3b 0 1 b 0c 2 1 c 2 由關系R通過運算得到關系S,則所使用的運算為A) 選擇 B)投影 C) 插入 D)連接(10)將E-R圖轉換為關系模式時,實體和聯系都可以表示為A) 屬性 B)鍵 C) 關系 D) 域(11)以下選項中合法的標識符是 A) 1-1 B)1—1 C)-11 D)1--(12)若函數中有定義語句:int k;,則 A)系統將自動給k賦初值0 B)這時k中值無定義 C)系統將自動給k賦初值-1 D)這時k中無任何值(13)以下選項中,能用作數據常量的是 A)o115 B) 0118 C)1.5e1.5 D) 115L(14)設有定義:int x=2; ,以下表達式中,值不為6的是A) x*=x+1 B) x++,2*x C)x*=(1+x) D)2*x,x+=2(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.141593(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)以下是if語句的基本形式:if (表達式) 語句,其中表達式A)必須是邏輯表達式 B)必須是關系表達式C)必須是邏輯表達式或關系表達式 D)可以是任意合法的表達式(18)有以下程序#include <stdio.h>main(){int x;</p><p>scanf(「%d」,&x);</p><p>if(x<=3); else</p><p>if(x!=10) printf(「%d\n」,x);</p><p>}程序運行時,輸入的值在哪個范圍才會有輸出結果A)不等於10的整數 B)大於3且不等於10的整數C) 大於3或等於10的整數 D)小於3的整數(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)以下程序中的變數已正確定義for(i=0;i<4;i++,i++for(k=1;k<3;k++);printf(「*」);程序段的輸出結果是A)******** B)**** C)** D)*(21)有以下程序#include<stdio.h>main(){char *s=(「ABC);</p><p>do</p><p>{printf(「%d」,*s%10);s++;</p><p>}while(*s);}注意,字母A的ASCII碼值為65。程序運行後的輸出結果是A)5670 B)656667 C)567 D)ABC(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)有以下程序#include<stdio.h>main(){ int a1,a2;char c1,c2;scanf(「%d%c%d%c」,&a1,&c1,&a2,&c2);printf(「%d,%c,%d,%c」,&1,c1,a2,c2);}若想通過鍵盤輸入,使得a1的值為12,a2的是為34,c1的值為字元a,c2的值為字元b,程序輸出結果是:12,a,34,b,則正確的輸入格式是(以下 代表空格,<CR>代表回車)A)12a34b<CR> B)12 a 34 b<CR>C)12,a,34,b<CR> D)12 a34 b<CR>(24)有以下程序#include<stdio.h>int f(int x,int y){return()y-x)*x);}main(){int a=3,b=4,c=5,d;</p><p>d=f(f(a,b),f(a,c));</p><p>printf(「%d\n」,d);</p><p>}程序運行後的輸出結果是A)10 B)9 C)8 D)7(25)有以下程序#include<stdio.h>void fun(char *s){while(*s)</p><p> { if(*s%2==0) printf(「%c」,*s);</p><p>s++;</p><p> }}main(){ char a[]={「good」}; fun(a);printf(「\n」);}注意:字母a的ASCII碼值為97,程序運行後的輸出結果是A)d B)go C)god D)good(26)有以下程序#include <stdio.h>void fun( int *a,int *b){int *c;</p><p>c=a;a=b;b=c;</p><p>}main(){int x=3,y-5,*P=&x,*q=&y;</p><p> fun(p,q);printf(「%d,%d,」,*p,*q);</p><p>fun(&x,&y);printf(「%d,%d\n」,*p,*q);</p><p>}程序運行後的輸出結果是A)3,5,5,3 B)3,5,3,5 C)5,3,3,5 D)5,3,5,3(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)以下函數按每行8個輸出數組中的數據void fun( int *w,int n){ int i; for(i=0;i<n;i++) {________</p><p> printf(「%d」,w);</p><p> } printf(「\n」);}下劃線處應填入的語句是A)if(i/8==0)print(「\n」); B) if(i/8==0)continue;C) if(i%8==0)print(「\n」); D) if(i%8==0)continue;(29)若有以下定義 int x[10],*pt=x;則對x數組元素的正確應用是A)*&x[10] B)*(x+3) C)*(pt+10) D)pt+3 (30)設有定義:char s[81];int i=10;,以下不能將一行(不超過80個字元)帶有空格的字元串真確讀入的語句或語句組是A gets(s) B)while((s[i++]=getchar())!=」\n」;s=」\0」;C)scanf(「%s」,s);D)do{scanf(「%c」,&s);}while(s[i++]!=」\n」);s=」\0」;(31)有以下程序#include <stdio.h>main(){ char *a[ ]={「abcd」,」ef」,」gh」,」ijk」};int I; for (i=0;i<4;i++) printf(「%c」,*a);}程序運行後輸出的結果是A)aegi B)dfhk C)abcd D)abcdefghijk(32)以下選項中正確的語句組是A)char s[];s=」BOOK!」; B) char *s;s={」BOOK!」};C)char s[10];s=」BOOK!」; D) char *s;s=」BOOK!」;(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)設函數中有整型變數n,為保證其在未賦值的情況下初值為0,應選擇的存儲類別是A)auto B) register C)static D)auto或register(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;i<4;i++) {b=fun(&a)+b;printf(「%d」,b);} printf(「\n」);}程序運行後輸出的結果是A)10 12 B)8 10 C)10 28 D)10 16(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)有以下程序#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)設有宏定義:#include 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整除是否餘1D)判斷m被5和7整除是否餘1(39)有以下程序#include <stdio.h>main(){ int a=5,b=1,t; t=(a<<2|b); printf(「%d\n」,t) }程序運行後的輸出結果是A)21 B)11 C)6 D)1(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 二、填空題(每空2分,共30分) 請將每一個空的正確答案寫在答題卡【1】至【15】序號的橫線上,答在試卷上不得分。(1)假設一個長度為50的數組(數組元素的下標從0到49)作為棧的存儲空間,棧底指針bottom指向棧底元素,棧頂指針top指向棧頂元素,如果bottom=49,top=30(數組下標),則棧中具有 【1】 個元素。(2)軟體測試可分為白盒測試和黑盒測試。基本路徑測試屬於 【2】 測試。(3)符合結構化原則的三種基本控制結構是:選擇結構、循環結構和 【3】 。(4)資料庫系統的核心是 【4】(5)在E-R圖中,圖形包括矩形框、菱形框、橢圓框。其中表示實體聯系的是 【5 】框。(6)表達式(int)((double)(5/2)+2.5)的值是【6】(7)若變數x、y已定義為int類型且x的值為99,y的值為9,請將輸出語句printf(【7】,x/y);補充完整,使其輸出的計算結果形式為:x/y=11(8)有以下程序#include <stdio.h>main( ){ char c1,c2; scanf(「&c」,&c1); while(c1<65||c1>90) scanf(「&c」,&c1); c2=c1+32; printf(「&c, &c\n」,c1,c2);}程序運行輸入65回車後,能否輸出結果、結束運行(請回答能或不能)【8】 。 (9)以下程序運行後的輸出結果是【9】#include <stdio.h>main( ){int k=1,s=0;</p><p>do{</p><p>if{((k&2)!=0)continue;</p><p>s+=k;k++;</p><p>}while(k)10);printf(「s=&d/n」,s);} (10)下列程序運行時,若輸入labced12df<回車> 輸出結果為【10】 #include <stdio.h>main( ){char a =0,ch;</p><p>while((ch=getchar())!=』\n』)</p><p>{if(a&2!=0&&(ch>』a』&&ch<=』z』)) ch=ch-『a』+』A』;</p><p>a++;putchar(ch);</p><p>}printf(「\n」);}(11)有以下程序,程序執行後,輸出結果是【11】#include <stdio.h>void fun (int *a){a[0=a[1];]}main(){int a[10]={10,9,8,7,6,5,4,3,2,1},i;for(i=2;i>=0;i--) fun{&a};for(i=0;i<10;i++) printf(「&d」,a);printf(「\n」);}(12)請將以下程序中的函數聲明語句補充完整#include <stdio.h>int【12】 ;main( ){int x,y,(*p)();</p><p>p=max;</p><p>printf(「&d\n」,&x,&y);</p><p>}Int max(int a,int b){return (a>b/a:b);}(13)以下程序用來判斷指定文件是否能正常打開,請填空#include <stdio.h>main( ){FILE *fp;</p><p>if (((fp=fopen(「test.txt」,」r」))==【13】))</p><p>printf(「未能打開文件!\n」);</p><p>else</p><p>printf(「文件打開成功!\n」);</p><p>(14)下列程序的運行結果為【14】</p><p>#include <stdio.h></p><p>#include <string.h></p><p>struct A</p><p>{int a;char b[10];double c;};void f (struct A *t);main(){struct A a=(1001,」ZhangDa」,1098,0);</p><p>f(&a);printf(「&d,&s,&6,if\n」,a.a,a.b,a.c);</p><p>}void f(struct A *t){strcpy(t->b,」ChangRong」); }(15)以下程序把三個NODETYPE型的變數鏈接成一個簡單的鏈表,並在while循環中輸出鏈表結點數據域中的數據,請填空#include <stdio.h>struct node{int data; struct node *next;};typedef struct node NODETYPE;main(){NODETYPE a,b,c,*h,*p;</p><p>a. data=10;b.data=20;c.data=30;h=&a;</p><p>b. next=&b;b.next=&c;c.next=』\0』;</p><p>p=h;</p><p>while(p){printf(「&d」,p->data);【15】;}} 2009年4月NCRE二級C參考答案選擇題:1~10: DACDC ABABC11~20:CBDDA CDBCB21~30:CDABA BACBC31~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

熱點內容
安卓用什麼管理軟體連接電腦 發布:2025-05-24 14:57:27 瀏覽:397
android解析復雜json 發布:2025-05-24 14:55:17 瀏覽:343
c語言跟c的區別 發布:2025-05-24 14:46:29 瀏覽:887
python源碼分析 發布:2025-05-24 14:41:31 瀏覽:594
吉利帝豪2021配置如何 發布:2025-05-24 14:33:42 瀏覽:516
伺服器怎麼改變休眠 發布:2025-05-24 14:29:14 瀏覽:485
星宸腳本 發布:2025-05-24 14:23:29 瀏覽:721
c語言實現濾波器 發布:2025-05-24 14:22:01 瀏覽:164
yumphpmemcache 發布:2025-05-24 14:08:07 瀏覽:842
伺服器集群部署ip 發布:2025-05-24 14:00:11 瀏覽:697