當前位置:編程學習大全網 - 編程語言 - 二級c公***基礎題庫

二級c公***基礎題庫

c語言總復習資料

壹 c語言的基本組成單位——函數。1.main();2庫函數;3.自定義函數。Abc();

二 函數的組成:1.函數的首部,函數的第壹行語句(包括函數的返回值類型、函數名、函數參數類型及函數參數名)。()不可省略,例如:void main() 2.函數體,包括函數的聲明部分(聲明在該程序中所要用到的函數)、定義部分(定義函數可能要用到的變量)、執行部分(用於實現函數的功能)。

三 函數必不可少的分號。

四 輸入輸出所使用的函數:scanf、getchar、gets、printf、putchar、puts等。

五 註釋:不能嵌套。習題94頁18題。

六 大小寫區分:printf與Printf之不壹樣。

七 C語言上機過程:編輯(.c)——>編譯(.obj)——>連接(.exe)——>運行得結果。

八 C程序執行是從main()函數開始,到main函數結束處結束。

九 進制轉換:著重掌握十、八、十六進制及相互轉換,原補碼(位運算中要用到)。

十 用戶自定義標識符:1.字母、數字、下劃線。2第壹個字母不能為數字。3.不能與c語言所定義的關鍵字相同,但可以與預定義標識符同。

十壹 常量:

1整形常量 十進制、八進制(以0開頭)、十六進制(以0x開頭)後兩種無負數。

2實型常量 2.78(小數點兩邊至少有壹邊要有數字)5.48e-3(e前必有數字,e後必為整數)

3字符型常量 a.壹般字符’a’ ;b.轉義字符:壹般轉義字符、八\十六進制轉義字符。’\n’,’\\’,’\t’,’\”’,’\64’,’\82’,’\x42’,’\xff’,’a12’.

4字符串常量 “a” vs ’a’

十二 變量 1.必須要先定義後使用;2變量三要素 變量類型 變量名 變量值

例1:下面不是c語言整形常量的是 A. 02 B. 0 C.038 D.0xAL

例2:合法的實型常量是A. 5E2.0 B.E-3 C.2E0 D 1.3E

例3:若有語句char a;並要將字符a賦值給變量a,則下列正確的賦值表達式是

A.a=”a” B.a=’a’ C.a=”97” D.a=’97’

例4:以下合法的定義是:

A. float _a=1.1e-1; B. double b=1+5e2.5; C.long do=0xfdaL; D.float 2_and=1-e-3;

十三.求余原則:1.兩邊都要為整數;

2.先取絕對值求余,余數與被除數符號相同。特別要註意’%’與’/’ 的區別。 -10/3 10/-3

十四. 賦值運算符及表達式:運算順序自右致左,左邊必須要是壹個變量(能夠存放東西)。

a=b=c=10(定義處不能這樣); x+y=10; x+1=10;

十五. 逗號表達式:a=(b=5,b+10); b=(a=4*9,a*2),a-3; 要考慮優先級。

十六. 類型轉換 char a=’a’; int b=32; float c=32.5;double s,d=32; s=a+b+c+d;

十七.強制類型轉換 float b=3.5;int a; a=(int)b;

例5:設有int x=11;則表達式(x++*1/3)的值是 A 3 B 4

例6:設有int a=1,b=1,c=1;a=a+++b+++c; 最終a、b、c的值是:a=4;b=2;c=1;

例7:有以下定義和語句組:float x=1;int y=2;y+=++x*++x;則最終y的值為:11

例8:int x=2;printf(“%d”,((x=4*5,x*5),x+25)); 45

例9:若變量已正確定義並賦值,以下符合c語言語法的表達式是

A.a:=b+1 B.a=b=c+2 C. int 18.5%3 D.a=a+7=c+b

十八 輸入輸出格式ch=getchar(); putchar(ch); scanf(“%d%f%c”,&a,&b,&c); printf(“%d,%d”,a,b);

例10:有以下程序,輸出的結果是

main(){int a;char c=10;float f=100.0;double x;

a=f/=c*=(x=6.5);printf(“%d %d %3.1f %3.1f\n”,a,c,f,x);}1 65 1.5 6.5 (習題集2.13)

十九.邏輯運算及其短路現象(對於邏輯與和邏輯或而言)

二十.關系運算符及表達式a>b>c 優先級要清楚(即關>邏輯)

二十壹.條件運算符及表達式a>b?a:c>d:c:d等價與a>b?a:(c>d?c:d) 設a=1,b=2,c=3,d=4; 4

例11:以下程序的輸出是 A. d=0 c=50 B.d=0 c=2 C.d=1 c=50 D.d=1 c=2

main(){int a=3,b=4,c=2,d; d=a<!b&&(c=50)>b; printf(“d=%d c=%d”,d,s);}

二十二.if語句 例12:以下程序輸出結果是

int i=1,j=1,k=2; if((j++||k++)&&i++) printf(“%d,%d,%d\n”,i,j,k); 2,2,2

if-else語句註意:if後只能管壹個語句

main(){int a=2,b=-1,c=2; if(a<b) if(b<0) c=0;

else c++; printf(“%d\n”,c);}

二十三.switch 語句 以下程序的輸出是: main(){int x=1,a=0,b=0;

switch(x) {case 0:b++;case 1:a++;case 2:a++;b++;} printf(“a=%d,b=%d\n”,a,b)} a=2,b=1

二十四.while vs do-while

main()

{int i=0,n=0;

while(n!=0){i++;++i} printf(“%d”,i);

}

main()

{int i=0,n=0;

do {i++;++i} while(n!=0); printf(“%d”,i);

}

二十五 break vs continue

註意:break語句只能出現在循環體和switch語句中而continue只出現在循體環中。

main()

{int sum,i;sum=0; for(i=10;i>0;i--) {if(i>5) continue;sum=sum+i;} printf("%d\n",sum);}

例13:以下程序的輸出是: main(){int a,y;a=5;y=0; a=7 y=7

do{ a+=2;y+=a;printf(“a=%d y=%d\n”,a,y);if(y>10) break; }while(a==7); }a=9 y=16

例14:以下程序的輸出是: main(){int k=4,n=0; for(;n<k;){n++;if(n%3!=0) continue;k--;}

printf(“%d,%d\n”,k,n);} 3,3

二十六.壹維數組的定義、賦初值、引用。註意:int a[10]={0};中括號例常量表達式 ,下標從0開始 例15:若有定義float y[5]={1,2,3};則下列描述正確的是:( )

A. y並不代表數組元素 B.定義此數組時不指定數組的寬度,定義效果壹樣

C.數組含有三個元素 D.a[3]的值是3

例16:以下程序的輸出是: main(){int z,y[3]={2,3,4};z=y[y[0]];printf(“%d”,z);} 4

例17:以下程序的輸出是: main(){int p[7]={11,13,14,15,16,17,18},i=0,k=0;

while(i<7&&p[i]%2) {k=k+p[i];i++}printf(“%d\n”,k);} 24

例18:以下程序的輸出是:

main(){int n[5]={0,0,0},i,k=2;for(i=0;i<k;i++) n[i]=n[i]+1;printf(“%d\n”,n[k])} 0

二十七.二維數組的定義、賦初值、引用

例19:main(){int a[3][3]={{1,2},{3,4},{5,6}},i,j,s=0; for(i=1;i<3;i++)

for(j=0;j<=i;j++) s+=a[i][j];printf(“%d\n”,s)} 18

例20:以下不能正確定義二維數組的是:

A int a[2][2]={{1},{2}};B int a[][2]={1,2,3};C int a[2][2]={{1},2,3}; D int a[2][]={{1,2},{3,4}};

例21:若a是壹個m行n列的數組,則a[i][j]是數組的第( )個元素

A i*m+j B i*m+j+1 C i*n+j D i*n+j+1

二十八 字符數組的定義、賦初值、引用

1.char arr[10]={‘h’,’e’,’l’,’l’,’o’}; 2.char arr[]={‘h’,’e’,’l’,’l’,’o’,’\0’};

3.char arr[10]={“hello”}; 4.char arr[10]=”hello”;

二十九 字符串輸入輸出 若char str[10]=”hello”,arr[10]=”me”;

scanf(“%s”,str); printf(“%s”,str); gets(str); puts(str);

strcpy(arr,str); strcmp(str,arr); strlen(str); strcat(str,arr);

例22:以下程序的輸出是:

main(){char st[20]=”hel\0lo\t”;printf(“%d%d\n”,strlen(st),sizeof(st))} 3,20

例23:以下程序的輸出是:char s[]=”\\141\141abc\t”;printf(“%d\n”,strlen(s));9

三十 指針與字符串 char *a; a=”hello”; char a[10]; a=”hello”;

例24:以下選項中正確的語句組是:( ) A.char s[8];s={“Beijing”};

B.char *s;s={“Beijing”}; C.char s[8];s=”Beijing”; D.char *s;s=”Beijing”;

三十壹 有參函數的聲明、定義、與調用。

float add(float x,float y);/*函數的聲明*/

mai()

{int a=3.5,b=4.0,d;

d=add(a,b);/*函數的調用*/

}

float add(float x,float y)/*函數的定義*/

{return x+y;}

三十二 函數的嵌套調用與遞歸調用

double fun1(double a) {return a*=a;}

double fun2(double x,double y)

{ double a=0,b=0;

a=fun1(x);b=fun1(y);

return (int)(a+b);}

main()

{double w;w=fun2(1.1,2.0);

printf("%f\n",w);} /*嵌套調用*/

long fib(int n)

{if(n>2) return (fib(n-1)+fib(n-2));

else return 2;}

main(){printf(“%d\n”,fib(3));}/*遞歸調用*/

三十三 函數中的值傳遞與地址傳遞(不管是傳遞什麽,實質都是傳值,只不過壹個是傳遞地址值而已)

func(int a){a=100;} func(int a[]) {a[0]=100;}

main(){int a=10;func(a);printf(“%d”,a);} main(){int a[1];a[0]=10;func(a);printf(“%d”,a[0]);}

三十四 局部變量與全局變量:局部變量的存儲類型分為自動型(auto)、寄存器型(register)、靜態類型(static),其中auto型和register型的變量的存儲空間是動態的,程序壹結束,其值就消失。而static類型的變量,程序結束後其值仍然存在。全局變量是靜態的變量。

int a=5;

fun(int b) {static int a=10;a+=b++;printf(“%d”,a);}

main(){int c=20;fun(c);a+=c++;printf(“%d\n”,a);} 3025 如果在main中再加壹個fun(c)呢?305025

三十五 宏命令與文件包含

#define N 10

#define S(x) x*x/*只要把這三個define語句放到壹個文件hong.h裏面*/

#define f(x) (x*x)/*再在主函數前加壹個#include “hong.h”,程序運行結果壹樣*/

main(){int i1,i2; i1=1000/S(N); i2=1000/f(N); printf(“%d %d”,i1,i2);}1000 10

三十六 指針變量的定義、初始化、運算

main()

{int n=5,*p=&n;printf(“the address is :%d\n”,p);

printf(“the data is:%d\n”,*p);

printf(“&*p is:%d\n”,&*p);

printf(“*&nis:%d\n”,*&n);}

例24:設有定義int n=0,*p=&n;則正確的賦值語句是:A. p=1; B.*p=&n; A選項不行,因p中應存放壹個地址值對於B選項,因p已經指向了n這個存儲單元,實際上相當於n=5 。

三十七 指針與壹維數組

int a[10],*p;/*a與p是不同的,a是數組名是常量,不能執行a++;a+=1的操作,p則可以*/

p=&a[0];p=a;/*這兩個語句等價,都是讓p指針指向這個數組*/

執行上述語句後:p[i]等價於a[i];*(p+i)等價於*(a+i)

三十八 指針與二維數組:下面給出了引用二維數組第i行第j列元素的不同方式

1. a[i][j];

2. 因a[i]表示第i行的首地址,a[i]+j表示第i行第j列的地址,所以*(a[i]+j)表示第i行第j列的值。

3. 又因a[i]可以寫成*(a+i),所以2中的表達式又可以寫成*(*(a+i)+j)。

4. 把1中的a[i]變成*(a+i),後面的不變,故又可寫成(*(a+i))[j]。

三十九 通過行指針引用二維數組

int a[4][4],(*p)[4];p=a;

四十 通過指針數組引用二維數組元素

int *p[4],a[4][4]; for(i=0;i<4;i++) p[i]=a[i];

以上兩個知識點,像以上這樣賦值後,要引用第i行第j列元素時,只需要把a改成p即可。

四十壹 函數指針與指針函數

int f(int x) {……} main() {int (*p)(); int a,b=2;p=f;a=(*p)(b); a=f(b);a=p(b);……}

函數指針:返回值是指針(地址)的函數。 int *func(int a,int b);

例25:int a[]={0,1,2,3,4,5,6,7,8,9},*p=a,i;其中0<=i<=9,下列對數組引用不正確的是:

A. a[p-a] B. *(&a[i]) C. p[i] D.a[10]

例 26:若定義int a[3][2];能正確表示t數組元素的地址的表達式是 A. &a[3][2] B.a[3] C. a[1] D.*a[2]

例28:以下程序輸出結果是:A. 69825 B.63825 C.6385 D.693825

main(){char ch[2][5]={“6937”,”8254”},*p[2]; int i,j,s=0; for(i=0;i<2;i++) p[i]=ch[i];

for(i=0;i<2;i++) for(j=0;p[i][j]>’\0’;j+=2) s=10*s+p[i][j]-‘0’; printf(“%d\n”,s); }

四十二 結構體的定義、賦初值

struct student {int num;char name[10];} *p,stu[2]={{123,”zhang”},{124,”li”}};p=stu;

typedef struct student {} STU; 在這個語句後就可以用STU來定義結構體變量了。

例:STU a,*p;等價於 struct student a,*p;

四十三 結構體變量的引用

printf(“%d”,stu[1].num); printf(“%d”,stu[1].name ); printf(“%d”,p[1]->num);

printf(“%d”,p[1]->name); printf(“%d”,stu);則不對

四十四 malloc、calloc、free函數及鏈表的操作 鏈表操作見書p120 int *p,*pint; float *q; p=(int*)malloc(sizeof(int)); q=(float*)malloc(sizeof(float)); pint=(int*)calloc(10,sizeof(int)); free(p); 習題集12章16題。

例29:下列賦值語句正確的是 struct worker {int num;char *name;}*p,a;

A. worker.num=1; B.p.num=1; C.*p.num=1; D.a.num=1;

例30:在16位pc環境下,下列程序運行的結果是:(此題大家有印象即可,不必深究)

struct worker {int num;char *name;}a; main(){printf(“%d”,sizeof(a))} 4(若32位則是8)

例31:設有如下定義:struct ss{char name[10]:int age:char sex:}stu[3],*p=std;下面各輸入語句錯誤的是:( )

A. scanf(“%d”,&(*p).age); B.scanf(“%s”,&std.name); C.scanf(“%c”,&std[0].sex); D.scanf(“%c”,&(p->sex));

因為std是表示是地址,而地址表示不應該是這樣的,應該是&(std->name);

四十五 位運算 ~、<<、>>、|、& 、^、例5.4

四十六 文件的打開及對文件的操作 FILE *fp;char str[10]=”hello”;int a,b;

1. if((fp=fopen(“in.dat”,”rb”))==NULL) printf(“Unable to open the file!”);/*重點註意打開文件的方式,特別註意以”w”,”r+”,”w+”,”a”方式打開,對文件的影響。*/

2. fclose(fp);/*關閉文件*/ feof(fp);/*測試文件是否結束,如到了則返回1,否則返回0*/

3. fseek(fp,12,SEEK_SET) /*將文件指針移動到文件起始位置後面的第12個字節處*/

4. fseek(fp,12,SEEK_END)/* 將文件指針移動到文件倒數第12個字節處*/

5. fseek(fp,0,SEEK_SET) /*將文件指針移動到文件起始位置同rewind(fp)函數*/

6. fseek(fp,12,SEEK_END)/* 將文件指針移動到文件末尾*/

7. ftell(fp); ch=fgetc(fp); putc(ch,fp); fgets(str,n,fp); fputs(str,fp);

8. fscanf(fp,”%d%d”,&a,&b);/*從fp所指向的文件中取出的兩數分別存放在a和b中*/

9. fprintf(fp,”%d%d”,a,b);/*把a和b中所存放的數據輸出(存放)到fp所指向的文件中*/

10. fread(str,size,count,fp);/*從fp所指向的文件中取出size*count個字節存放到str數組中*/

11. fwrite(str,size,count,fp);/*把str數組中的size*count個字節存放到fp所指向的文件中*/

妳有相關的書嗎?這是我當年考試用過的壹些資料呀!希望對妳有幫助!!

  • 上一篇:如何創建網站
  • 下一篇:圓形三角形波浪線直線寫作文
  • copyright 2024編程學習大全網