C语言二级考试都是从题库抽取吗,全國c語言二級考試題庫

❶ 全國計算機二級c語言每年考試題庫都一樣嗎

題庫的變化不大,題型都是相同的。計算機二級考試包含:程序設計/辦公軟體高級應用,考核內容包括計算機語言與基礎程序設計能力,要求參試者掌握一門計算機語言,可選類別有高級語言程序設計類、資料庫程序設計類等;

辦公軟體高級應用能力,要求參試者具有計算機應用知識及MS Office辦公軟體的高級應用能力,能夠在實際辦公環境中開展具體應用。從2013年開始全國計算機等級考試已從傳統的筆試和上機考試改革成無紙化考試,二級Delphi科目從2013年上半年開始停考。

ea1cff44e9467af75984cdedba7397d5.png

(1)全國c語言二級考試題庫擴展閱讀

報考二級6個科目考試的新生,全部採用無紙化考試(即全部上機考試),取代傳統的考試模式(筆試加上機)。參加二級7個科目補考的老生,仍按照傳統模式參加補考。無紙化考試中,傳統考試的筆試部分被移植到計算機上完成,考核內容和要求不變。

無紙化考試時間為120分鍾,滿分100分,總分達到60分可以獲得合格證書。沒有獲得合格證書的考生,無補考,下一次需重新以新考生身份報名參加考試。

❷ 全國計算機二級考試有題庫嗎

全國計算機等級考試的上機題都是在題庫中隨機抽取的,題庫有100套。網上的題一般都只有幾套,而且那幾套一般都沒什麼代表性,如果你想一次性通過的話,就去買套上機題庫吧,認真做,絕對是原題。

❸ 全國計算機等級考試二級c語言考的是題庫里的題嗎都是歷年的題庫嗎題庫在哪買,會考原題嗎

全國計算機等級考試的上機題都是在題庫中隨機抽取的,題庫有100套。網上的題一般都只有幾套,而且那幾套一般都沒什麼代表性,如果你想一次性通過的話,就去買套上機題庫吧,認真做,絕對是原題。

❹ 全國二級C語言考試形式和考試題目類型是什麼

2013年無紙化考試:

選擇題:40分,程序填空題:18分,程序修改題:18分,程序設計題:24分。

60分且程序題達36分,才算過。。

今年沒有填空題,而 且都是機試。

真題庫,其中選擇題8套,共320題,程序題105套,共315題。

考生考試時,按考點隨機抽取40到題組成選擇題部分,程序題從題庫105套中隨機抽取一套。。

❺ 2020年全國計算機等級考試二級c語言上機精選題庫(共50套)

❻ 全國計算機等級考試二級C語言歷年試題及答案

2010年9月全國計算機等級考試二級C語言筆試試題及答案

一、選擇題((1)-(10)每題2分,(11)-(50)每題1分.共分))

(1)下列選項中不屬於軟體生命周期開發階段任務的是

A)詳細設計 B)概要設計 C)軟體維護 D)軟體測試

(2)樹是結點的集合,它的根結點數目是

A)有且只有1 B)1或多於1 C)0或1 D)至少2

(3)在面向對象方法中,實現信息隱蔽是依靠

A)對象的繼承 B)對象的多態 C)對象的封裝 D)對象的分類

(4)程序設計語言的基本成分是數據成分、運算成分、控製成分和

A)語句成分 B)變數成分 C)對象成分 D)傳輸成分

(5)冒泡排序在最壞情況下的比較次數是

A)n/2 B)nlog2n C)n(n-1)/2 D)n(n+1)/2

(6)下列敘述中,不屬於軟體需求規格說明書的作用的是

A)作為確認測試和驗收的依據

B)反映出用戶問題的結構,可以作為軟體開發工作的基礎和依據

C)便於用戶、開發人員進行理解和交流

D)便於開發人員進行需求分析

(7)下列敘述中錯誤的是

A)一個C語言程序只能實現一種演算法 B)C程序可以由多個程序文件組成

C)C程序可以由一個或多個函數組成 D)一個函數可單獨作為一個C程序文件存在

(8)下列不屬於軟體工程的3個要素的是

A)方法 B)過程 C)工具 D)環境

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

A)資料庫系統是一個獨立的系統,不需要操作系統的支持

B)資料庫技術的根本目標是要解決數據的共享問題

C)資料庫管理系統就是資料庫系統

D)以上三種說法都不對

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

A)每個C程序文件中都必須有一個main()函數

B)在C程序的函數中不能定義另一個函數

C)C程序可以由一個或多個函數組成

D)在C程序中main()函數的位置是固定的

(11)將E-R圖轉換到關系模式時,實體與聯系都可以表示成

A)屬性 B)關系 C)鍵 D)域

(12)下列定義變數的語句中錯誤的是

A)double int_; B)int _int; C)char For D)float USS

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

A)C語言編譯時不檢查語法 B)C語言的子程序有過程和函數兩種

C)C語言的函數可以嵌套定義 D)C語言的函數可以嵌套調用

(14)以下選項中,合法的一組C語言數值常量是

A) 0x8A B)12 C).177 D) 028

(15)以下敘述中正確的是

A)構成C程序的基本單位是函數

B)可以在一個函數中定義另一個函數

C)main()函數必須放在其他函數之前

D)所有被調用的函數一定要在調用之前進行定義

(16)若在定義語句:int a,b,c,*p=&c;之後,接著執行以下選項中的語句,則能正確執行的語句是

A)scanf("%d",&p); B)scanf("%d%d%d",a,b,c);

C)scanf("%d",p); D) scanf("%d",a,b,c);

(17) 有以下程序

main()

{int x,y,z;

x=y=1;

z=x++,y++,++y;

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

}

程序運行後的輸出結果是

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

(18) 若已定義:int a=25,b=14,c=19;以下三目運算符(?:)所構成語句的執行後a<=25&&b--<=2&&c?printf("***a=%d,b=%d,c=%d\n",a,b,c):printf("###a=%d,b=%d,c=%d\n",a,b,c);程序輸出的結果是

A)***a=25,b=13,c=19 B)***a=26,b=14,c=19

C)### a=25,b=13,c=19 D)### a=26,b=14,c=19

(19)下列程序段的輸出結果是

int a=1234;

float b=123.456;

double c=12345.54321;

printf("-,%2.1f,%2.1f",a,b,c);

A)無輸出 B)12,123.5,12345.5 C)1234,123.5,12345.5 D)1234,123.4,1234.5

(20)有以下程序

main()

{int a=0,b=0;

a=10; /*給a賦值

b=20; 給b賦值 */

printf("a+b=%d\n",a+b); /* 輸出計算結果 */

}

程序運行後輸出結果是

A)30 B)a+b=30 C)a+b=0 D)出錯

(21)若運行以下程序時,從鍵盤輸入 ADescriptor(表示回車),則下面程序的運行結果是

#include

main()

{ char c;

int v0=1,v1=0,v2=0;

do{ switch(c=getchar())

{ case ′a′:case ′A′:

case ′e′:case ′E′:

case ′i′:case ′I′:

case ′o′:case ′O′:

case ′u′:case ′U′:v1+=1;

default:v0+=1;v2+=1;

}

} while(c!=′\n′);

printf("v0=%d,v1=%d,v2=%d\n",v0,v1,v2);

}

A)v0=11,v1=4,v2=11 B)v0=8,v1=4,v2=8

C)v0=7,v1=4,v2=7 D)v0=13,v1=4,v2=12

(22) 有以下程序

#include

main()

{int y=9;

for( y>0;y--)

if(y%3= =0) printf("%d",--y);

}

程序的運行結果是

A)732 B)433 C)852 D)874

(23) 設有以下程序段

int x=0,s=0;

while(!x!=0)s+=++x;

printf("%d",s);

A)運行程序段後輸出0 B)運行程序段後輸出1

C)程序段中的控製表達式是非法的 D)程序段執行無限次

(24)有以下程序

fun(int x,int y){return(x+y);}

main()

{int a=1,b=2,c=3,sum;

sum=fun((a++,b++b,a+b),c++);

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

}

執行後的輸出結果是

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

(25)執行下面的程序段後,變數k中的值為

int k=3, s[2];

s[0]=k; k=s[1]*10;

A)不定值 B)35 C)31 D)20

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

A)改變函數形參的值,不會改變對應實參的值

B)函數可以返回地址值

C)可以給指針變數賦一個整數作為地址值

D)當在程序的開頭包含文件stdio.h時,可以給指針變數賦NULL

(27)以下程序段的描述,正確的是

x=-1;

do

{x=x*x;} while(!x);

A)是死循環 B)循環執行兩次 C)循環執行一次 D)有語法錯誤

(28)有以下程序

fun(int x,int y)

{static int m=0,i=2;

i+=m+1;m=i+x+y; return m;

}

main()

{int j=1,m=I,k;

k=fun(j,m); printf("%d",k);

k=fun(j,m); printf("%d\n",k)

}

執行後的輸出結果是

A)5,5 B)5,11 C)11,11 D)11,5

(29)有以下程序

fun(int x)

{int p;

if(x==0║x= =1) return(3);

p=x-fun(x=2);

retum p;

}main()

{ prinf("%d\n",fun(7));}

執行後的輸出結果是

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

(30)在16位編譯系統上,右有定義int a[ ]={10,20,30},*p=&a;,當執行p++;後,下列說法錯誤的是

A)p向高地址移了一個位元組 B)p抽高地址移了一個存儲單元

C)p向高地址移了兩個位元組 D)p與a+1等價

(31)有以下程序

main()

{int a=1,b=3,c=5;

int *p1=&a,*p2=&b,*p=&c;

*p=*p1*(*p2);

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

}

執行後的輸出結果是

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

(32)下列程序執行後的輸出結果是

void func1(int i);

void func2(int i);

char st[]="hello,friend!";

void func1(int i)

{ printf("%c",st[i]);

if(i<3){i+=2;func2(i);}

}

void func2(int i)

{ printf("%c",st[i]);

if(i<3){i+=2;func1(i);}

}

main()

{ int i=0; func1(i); printf("\n");}

A)hello B)hel C)hlo D)hlm

(33)在下述程序中,判斷i>j共執行的次數是

main()

{ int i=0, j=10, k=2, s=0;

for (;;)

{ i+=k;

if(i>j)

{ printf("%d",s);

break;

} s+=i;

}

}

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

(34)以下函數返回a所指數組中最大值所在的下標值

fun(int *a,int n)

{ int i,j=0,p;

p=j;

for(i=j;iif(a[i]>a[p]);

return(p);

}

在下劃線處應填入的內容是

A)i=p B)a[p]=a[i] C)p=j D)p=i

(35)下列程序執行後的輸出結果是

main()

{ int a[3][3], *p,i;

p=&a[0][0];

for(i=1; i<9; i++)p[i]=i+1;

printf("%d\n",a[1][2]);

}

A)3 B)6 C)9 D)隨機數

(36) 有以下程序

#include

void fun(int *a,int n)/*fun函數的功能是將a所指數組元素從大到小排序*/

{int t,i,j;

for(i=0;ifor(j=i+1;jif (a}

main()

{int c[10]={1,2,3,4,5,6,7,8,9,0},i;

fun(c+4,6);

for (i=0;i<10;i++) printf("%d,",c);

printf("\n");

}

程序運行的結果是

A)1,2,3,4,5,6,7,8,9,0, B)0,9,8,7,6,5,1,2,3,4,

C) 0,9,8,7,6,5,4,3,2,1, D)1,2,3,4,9,8,7,6,5,0,

(37)以下程序的輸出結果是#include

void prt (int *x, int*y, int*z)

{ printf("%d,%d,%d\n",++*x,++*y,*(z++));}

main()

{ int a=10,b=40,c=20;

prt (&a,&b,&c);

prt (&a,&b,&c);

}

A)11,42, 31

12,22,41

B)11,41,20

12,42,20

C)11,21,40

11,21,21

D)11,41,21

12,42,22

(38) 有以下程序:

#include

void fun(char *t,char *s)

{

while(*t!=0)t++;

while((*t++=*s++)!=0);

}

main()

{

char ss[10]=」acc」,aa[10]=」bbxxyy」;

fun(ss,aa);

printf(「%s,%s\n」,ss,aa);

}

程序運行結果是

A) accxyy , bbxxyy B) acc, bbxxyy

C) accxxyy,bbxxyy D) accbbxxyy,bbxxyy

(39) 有以下程序

#include

main()

{ FILE *fp; int i=20,j=30,k,n;

fp=fopen("d1.dat","w");

fprintf(fp,"%d\n",i);fprintf(fp,"%d\n",j);

fclose(fp);

fp=fopen("d1.dat","r");

fscanf(fp,"%d%d",&k,&n); printf("%d %d\n",k,n);

fclose(fp);

}

程序運行後的輸出結果是

A)20 30 B)20 50 C)30 50 D)30 20

(40) 有以下程序

main()

{int x[3][2]={0},I;

for(I=0;I<3;I++) scanf("%d",x[i]);

printf("%3d%3d%3d\n",x[0][0],x[0][1],x[1][0]);

}

若運行時輸入:246,則輸出結果為

A)2 0 0 B)2 0 4 C)2 4 0 D)2 4 6

(41)有以下程序

int add(int a,int b){return+b};}

main()

{int k,(*f)(),a=5,b=10;

f=add;

}

則以下函數調用語句錯誤的是

A)k=(*f)(a,b); B)k=add(a,b); C)k=*f(a,b); D)k=f(a,b);

(41)有以下程序

#include

main(int argc,char *argv[])

{int i=1,n=0;

while(i

printf(「%d\n」,n);

}

該程序生成的可執行文件名為:proc.exe。若運行時輸入命令行:

proc 123 45 67

則程序的輸出結果是

A)3 B)5 C)7 D)11

(42)有以下程序

void fun2(char a, char b){printi(「%b%c」,a,b);}

char a= 『A』,b= 『B』;

void fun1( ){ a= 『C』l b= 『D』; }

main( )

{ fun1( )

printf( 「%c%c」,a,b);

fun2(『E』, 『F』);

}

程序的運行結果是

A)CDEF B)ABEF C)ABCD D)CDAB

(43)有以下程序

#include

#define N 5

#define M N+1

#define f(x) (x*M)

main()

{int i1,i2;

i1=f(2);

i2=f(1+1);

printf(「%d %d\n」,i1,i2);

}

程序的運行結果是

A)12 12 B)11 7 C)11 11 D)12 7

(44)設有以下語句

typedef struct TT

{char c; int a[4];}CIN;

則下面敘述中正確的是

A)可以用TT定義結構體變數 B)TT是struct類型的變數

C)可以用CIN定義結構體變數 D)CIN是struct TT類型的變數

(45)有以下結構體說明、變數定義和賦值語句

struct STD

{char name[10];

int age;

char sex;

}s[5],*ps;

ps=&s[0];

則以下scanf函數調用語句中錯誤引用結構體變數成員的是

A)scanf(「%s」,s[0].name); B)scanf(「%d」,&s[0].age);

C)scanf(「%c」,&(ps>sex)); D)scanf(「%d」,ps>age);

(46)若有以下定義和語句

union data

{ int i; char c; float f;}x;

int y;

則以下語句正確的是

A)x=10.5; B)x.c=101; C)y=x; D)printf(「%d\n」,x);

(47)若變數已正確定義,則以下語句的輸出結果是

s=32; s^=32;printf(「%d」,s);

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

(48) 若程序中有宏定義行:#define N 100 則以下敘述中正確的是

A)宏定義行中定義了標識符N的值為整數100

B)在編譯程序對C源程序進行預處理時用100替換標識符N

C) 對C源程序進行編譯時用100替換標識符N

D)在運行時用100替換標識符N

(49)以下敘述中正確的是

A)C語言中的文件是流式文件,因此只能順序存取數據

B)打開一個已存在的文件並進行了寫操作後,原有文件中的全部數據必定被覆蓋

C)在一個程序中當對文件進行了寫操作後,必須先關閉該文件然後再打開,才能讀到第1個數據

D)當對文件的讀(寫)操作完成之後,必須將它關閉,否則可能導致數據丟失

(50)有以下程序

#include

main()

{FILE *fp; int i;

char ch[]=」abcd」,t;

fp=fopen(「abc.dat」,」wb+」);

for(i=0;i<4;i++)fwriter&ch[],1,1fp;

fseek(fp,-2L,SEEK_END);

fread(&t,1,1,fp);

fclose(fp);

printf(「%c\n」,t);

}

程序執行後的輸出結果是

A)d B)c C)b D)a

二、填空題(每空2分,共40分)

(1)在面向對象方法中,類之間共享屬性和操作的機制稱為 【1】 。

(2)一個關系表的行稱為 【2】 。

(3)耦合和內聚是評價模塊獨立性的兩個主要標准,其中 【3】 反映了模塊內各成分之間的聯系。

(4)線性表的存儲結構主要分為順序存儲結構和鏈式存儲結構.隊列是一種特殊的線性表,循環隊列是隊列的【4】存儲結構.

(5) 【5】 的任務是診斷和改正程序中的錯誤。

(6) 以下程序的輸出結果是【6】.

#include

main()

{ int n=12345,d;

while(n!=0){ d=n%10; printf("%d",d); n/=10;}

}

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

main()

{

int m=011,n=11;

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

}

(8)有以下程序,若運行時從鍵盤輸入:18,11,則程序輸出結果是 【8】 。

main()

{ int a,b;

printf("Enter a,b:");scanf("%d,%d",&a,&b);

while(a!=b)

{ while(a>b) a-=b;

while(b>a) b-=a;

}

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

}

(9) 有以下程序段,且變數已正確定義和賦值

for(s=1.0,k=1;k<=n;k++) s=s+1.0/(k*(k+1));

printf("s=%f\n\n",s);

請填空,使下面程序段的功能為完全相同

s=1.0;k=1;

while(_【9】_______){ s=s+1.0/(k*(k+1)); _【10】_______;}

printf("s=%f\n\n",s);

(10)執行以下程序的輸出結果是【11】______.

#include

main()

{ int i,n[4]={1};

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

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

}

(11)以下程序中函數f的功能是在數組x的n個數(假定n個數互不相同)中找出最大最小數,將其中最小的數與第一個數對換,把最大的數與最後一個數對換.請填空.

#include

viod f(int x[],int n)

{ int p0,p1,i,j,t,m;

i=j=x[0]; p0=p1=0;

for(m=0;m{ if(x[m]>i) {i=x[m]; p0=m;}

else if(x[m]}

t=x[p0]; x[p0]=x[n-1]; x[n-1]=t;

t=x[p1];x[p1]= _【12】_______; 【13】______=t;

}

main()

{ int a[10],u;

for(u=0;u<10;u++) scanf("%d",&a);

f(a,10);

for(u=0;u<10;u++) printf("%d",a);

printf("\n");

}

(12)下列程序中的函數strcpy2()實現字元串兩次復制,即將t所指字元串復制兩次到s所指內存空間中,合並形成一個新的字元串。例如,若t所指字元串為efgh,調用strcpy2後,s所指字元串為efghefgh。請填空。

#include

#include

void strcpy2(char *s,char *t)

{ char *p=t;

while(*s++=*t++);

s= 【14】 ;

while( 【15】 =*p++);

}

main()

{ char str1[100]="abcd",str2[]="efgh";

strcpy2(str1 ,str2); printf("%s\n",str1);

}

(13)以下程序統計從終端輸入的字元中大寫字母的個數,num[0]中統計字母A的個數,num[1]中統計字母B的個數,其它依次類推.用#號結束輸入,請填空.

#include

#include

main()

{ int num[26]={0},i; char c;

while((_【16】_______)!='#')

if(isupper(c)) num[c-『A』]+= 【17】_______;

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

Printf("%c:%d\n",i+'A',num);

}

(14)以下程序中,函數fun的功能是計算x2-2x+6,主函數中將調用fun函數計算:

y1=(x+8)2-2(x+8)+6

y2=sin2(x)-2sin(x)+6

請填空。

#include "math.h"

double fun(double x) { return(x*x-2*x+6); }

main()

{

double x,y1,y2;

printf("Enter x:"); scanf("%lf",&x);

y1=fun( 【18】 );

y2=fun( 【19】 );

printf("y1=%lf,y2=%lf\n",y1,y2);

}

(15) 以下程序的輸出結果是_【20】______.

#include

#define M 5

#define N M+M

main()

{ int k;

k=N*N*5; printf("%d\n",k);

}

一、選擇題答案:

1-10:CACDC DADBA 11-20:BDDBA CCCCB 21-30:DCBCA CCBCA

31-40:CCDAB DCDAB 41-50:CABCD BBBDB

二、填空題答案:

1.繼承 2. 元組 3.內聚 4.順序 5. 程序調試

6. 54321 7.10 11 8. 1 9.k<=n k++

10. 3 7 5 11.x[0] x[0] 12.s--,*s++ 13.c=getchar() 14. (x+8),sin(x) 15.55

希望對你有所幫助

❼ 全國計算機等級考試二級C語言的考試題目都是從《C語言題庫》裡面抽取的題目嗎

全國計算機等級考試二級C語言的考試題目的小題不是從《C語言題庫》中抽取的,後面的大題即編程題全部是從最近的一年的《C語言題庫》中抽取的。考題大部分是C語言,少部分是演算法與數據結構裡面的東西。就算不是《C語言題庫》題庫里的題,但是題型都差不多的。

c語言是一門面向過程、抽象化的通用程序設計語言,廣泛應用於底層開發。C語言具有高效、靈活、功能豐富、表達力強和較高的可移植性等特點,在程序設計中備受青睞。C語言編譯器普遍存在於各種不同的操作系統中,例如Microsoft Windows、macOS、Linux、Unix等。C語言的設計影響了眾多後來的編程語言,例如C++、Objective-C、Java、C#等。

ea1cff44e9467af75984cdedba7397d5.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值