版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
C语言试题库
一、单项选择
第一章C语言概述
(1)一个C程序的执行是从—
A、本程序的MAIN函数开始,到MAIN函数结束。
B、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束。
C、本程序的MAIN函数开始,到本程序的最后一个函数结束。
D、本程序文件的第一个函数开始,到本程序的MAIN函数结束。
(2)以下叙述正确的是一
A、在C程序中,MAIN函数必须位于程序的最前面。
B、C程序的每行中只能写一条语句。
C、C语言本身没有输入输出语句。
D、在对一个C程序进行编译的过程中,可发现注释中的拼写错误。
(3)C语言规定,在一个源程序中,MAIN主函数的位置是在:—
A、必须在最前面。
B、必须在系统调用的库函数的后面
C、可以在任意位置。
D、必须在最后面
(4)一个C程序是由:
A、一个主程序和若干子程序组成
B、函数组成
C、若干过程组成
D、若干子程序组成
(5)以下叙述不正确的是:—
A、一个C源程序可由一个或多个函数组成
B、一个C源程序必须包含一个MAIN函数
C、C程序的基本组成单位是函数
D、在C程序中,注释说明只能位于一条语句的后面
第二章数据类型、运算符与表达式
(1)若x,i,j,k都是int型变量,则计算下面表达式后,x的值为
x=(i=4,j=16,k=32)
A、4
B、16
C、32
D、52
(2)下列四组选项中,均不是C语言键字的选项是一
A、define,IF,type
B、getc,char,printf
C、include,scanf,case
E、if,struct,type
(3)下面四个选项中,均是不合法的用户标识符的选项是一
A、A,P_0,do
B、float,1aO,_A
C、b-a,goto,int
D、_123,temp,INT
(4)若有代数式3ae/bc,则正确的C语言表达式是一
A、a/b/c*e*3
B、3*a*e/bc
C、3*a*e/b*c
D、a*e/c/b*3
(5)已知各变量的类型说明如下:
intk,a,b;
unsingedlongw=5;
doublex=1.42;
则以下不符合C语言语法的表达式是一
A、x%(-3)
B、w+=-2;
C、k=(a=2,b=3,a+b)
D、a+=a-=(b=4)*(a=3)
第三章简单c程序设计
(1)putchar函数可以向终端输出一个
A、整型变量表达式值
B、实型变量值
C、字符串
D、字符或字符型变量值
(2)若x,y均定义为血型,z定义为double型,以下合法的scanf函数调用语句是
A、scanf(tt%d%lx,%le,\&x,&y,&z);
B、scanfC4%2d*%d%lf\&x,&y,&z);
C、scanf("%x%*d%o'[&x,&y,&z);
D、scanf(u%x%o%6.2f\&x,&y,&z);
⑶当输入数据的形式为:25,13,10〈回车〉时,以下程序的输出结果为
main()
{intx,y,z;
scanf(u%d%d%d,,,&x,&y,&z);
primf("x+y+z=%d\n”,x+y+z);
A、x+y+z=48
B、x+y+z=35
C、x+z=35
D、不确定值
(4)以下能正确的定义整型变量a,b和c,并对它们赋初值为5的语句是一
A、inta=b=c=5;
B、inta,b,c=5;
C、a=5,b=5,c=5;
D、a=b=c=5;
(5)若有以下定义,则正确的赋值语句是一
inta,b;floatx;
A、a=l,b=2;
B、b++;
C、a=b=5;
D、b=int(x);
第四章选择结构程序设计
(1)能正确表示“当x的值在[1,10]和[200,210]的范围为真,否则为假”的表达式是
A、(x>=1)&&(X<=10)&&(x.>=200)&&(x<=210)
B、(x>=l)||(xv=10)||(x.>=200)||(x<=210)
C、(x>=l)&&(x<=10)||(x.>=200)&&(x<=210)
D、(x>=l)||(x<=10)&&(x.>=200)||(x<=210)
(2)以下程序的运行结果是一
#include"stdio.h"
main()
{inta,b,d=241;
a=d/100%9;
b=(-l)&&(-l);
printf("%d,%d”,a,b);
)
A、6,1
B、2,1
C、6,0
D、2,0
(3)请阅读以下程序:
main()
{inta=5,b=0,c=0;
if(a+b+c)printfC***\n");
elseprintf("$$$\n*);
以上程序—。
A)有语法错误不能通过编译
B)可以通过编译但不能直接通过连接
C)输出***
D)输出$$$
(4)以下程序的运行结果是一。
main()
{intm=5;
if(m++>5)printf("%d\n”,m);
elseprintf("%d\n”,m——);
)
A)4
B)5
C)6
D)7
(5)为了避免在嵌套的条件语句中if-else中产生二义性,c语言规定:else子句总是与
相配对。
A)缩排位置相同的if
B)其之前最近的if
C)其之后最近的if
D)同一行上的if
第五章循环控制
(1)设有程序段
intk=10
while(k=0)k=k-l
则下面描叙正确的是o
A)while(k=0)k=k-l;
B)循环是无限循环
C)循环体语句一次也不执行
D)循环体语句执行一次
(2)下面程序段的运行结果是,
intn=0;
while(n++<=2);printf("%d”,n);
A)2
B)3
C)4
D)有语法错
(3)C语言中while和do-while循环的主要区别是。
A)do-while的循环体至少无条件执行一次
B)while的循环控制条件比do-while的循环控制条件严格
C)do・while允许从外部转到循环体内
D)do-while允许从外部转到循环体内
(4)以下能正确计算1*2*3*...*10的程序段是o
A)do{i=l;s=l;
s=s*i;
i++;
}while(I<=10);
B)do{i=l;s=0;
s=s*i;
i++;
}while(I<=10);
C)i=l;s=l;
do{s=s*i;
i++;
}while(I<=10);
D)i=l;s=0;
do{s=s*i;
i++;
}while(I<=10);
第六章数组
(1)在c语言中,引用数组元素时,其数组下标的数据类型允许是
A)整型常量
B)整型表达式
C)整型常量或整型表达式
D)任何类型的表达式
(2)以下能对二维数组a进行正确初始化的语句是。
A)inta⑵[]=({1,0,1},{5,2,3,}};
B)inta[][3]={{1.2,3},{4,5,6});
C)inta⑵[4]={1,2,3,},{4,5},{6}};
D)inta[][3]={{l,0,1},{},{1,1}};)
(3)若有说明:inta[3][4]={0};则下面正确的叙述是。
A)只有元素a[0]⑼可得到初值0
B)此说明语句不正确
C)数组a中各元素都可得到初值,但其值不一定为0
D)数组a中每个元素均可得到初值0
(4)下面程序(每行程序前面的数字表示行号)。
1main()
2(
3floata[10]={0};
4inti
5for(i=0;i<3;i++)scanf("%d”,&a[i];
6for(i=l;i<10;i++)a[O]=a[O]+a{i};
7printf("%f\n",a[O]);
8)
A)没有错误
B)第3行有错误
C)第5行有错误
D)第7行有错误
(5)若二维数组a有m歹ij,则计算机一元素在数组中位置的公式为。(假设a[0][0]
位于数组的第一个位置上。)
A)i*m+j
B)j*m+i
C)i*m+j-l
D)i*m+j+l
第七章函数
(1)以下正确的函数定义形式是O
A)doublefun(intx,inty)
C)doublefun(intx;inty)
D)doublefun(intx,inty)
E)doublefun(intx,y);
(2)以下正确的函数形式是o
A)doublefun(intx,inty)
{z=x+y;returnz;}
B)fun(intx,y)
{intz;
returnz;}
C)fun(x,y)
{intx,y;doublez;
z=x+y;returnz;}
D)doublefun(intx,inty)
{doublez;
z=x+y;returnz;}
(3)C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是
A)地址传递
B)单向值传递
C)由实参传给形参,再由形参传回给实参
D)传递方式
(4)C语言允许函数值型缺省定义,此时该函数值隐含的类型是
A)float型
B)int型
C)long型
D)double型
(5)下面函数调用语句含有实参的个数为。
func((exp1,exp2),(exp3,exp4,exp5));
A)1
B)2
C)4
D)5
第八章编译预处理命令
(1)请读程序:
#defineADD(x)x+x
main()
(
intm=l,n=2,k=3;
intsum=ADD(m+n)*k;
printf(usum=%d,,,sum);
)
上面程序的运行结果是o
A)sum=9
B)sum=10
C)sum=12
D)sum=18
(2)以下程序的运行结果是o
#defineMIN(x,y)(x)<(y)?(x)+(y)
main()
{intI=10,j=15,k;
k=10*MIN(I,j);
printf(44%d\n,\k);
)
A)10
B)15
C)100
D)150
(3)在宏定义#definePI3.14159中,用宏名PI代替一个
A)常量
B)单精度数
C)双精度数
D)字符串
(4)若有宏定义如下:
#defineX5
#defineYX+l
#defineZY*x/2
则执行以下printf语句后,输出结果是o
inta;a=Y;
printfC4%d\n,\Z);
printfC%d\n,,,-a);
A)7B)12C)12D)7
6655
(5)若有以下宏定义:
#defineN2
#defineY(n)((N+l)*n)
则执行语句z=2*(N+Y(5));后的结果是
A)语句有错误
B)z=34
C)z=70
D)z无定值
第九章指针
(1)以下程有错误,错误原因是
main()
{int*p,I;char*q,ch;
P=&I;
q=&ch;
*p=40;
*p=*q;
A)p和q的类型不一致,不能执行*P二*Q;语句
B)P中存放的是地址值,因此不能执行*P=40;语句
C)Q没有指向具体的存储单元,所以*Q没有实际意义
D)Q虽然指向了具体的存储单元,但该单元中没有确定值,所以不能执行*P=*Q;语
句
(2)已有定义intk=2;int*ptrl,*ptr2;且ptrl和ptr2均已指向变量K,下面不能正确执
行的赋值语句是.
A)k=*ptrl+*ptr2;B)ptr2=K;
C)ptrl=ptr2;D)k=*ptrl*(*ptr2);
(3)变量的指针,其含义是指该变量的.
A)值B)地址C)名D)一个标志
(4)若有语句int*point,a=4;和ponil=&a;下面均代表地址的一组选项是.
A)a,point,*&a
B)&*a,&a,*point
C)*&point,*point,&a
D)&a,&*point,point
(5)下面能正确进行字符串赋值操作的是.
A)chars[5]=CtABCDE,,J;
B)chars[5]={<A,;B\,C,;D,;E,);
C)char*S;s="ABCDE”;
D)char*S;scanfC%s,,,s);
(6)若有以下定义,则对A数组元素的正确引用是.
A)*&a[5]
B)*a+2
C)*(P+5)
D)*(a+2)
(7)若有以下定义,则对a数组元素地址的正确引用是>
A)p+5
B)*a+l
C)&a+l
D)&a[0]
⑻若有定义:inta[2][3];则对a数组的第I行第J列(假设I,J已正确说明并赋值)元素值的正
确引用为.
A)*(*(a+I)+J)
B)(a+I)U]
C)*(a+I+j)
D)*(a+I)+j
(9)若有定义:inta[2][3];则对a数组的第i行第j列(假设i,j已正确说明并赋值)元素地址的正
确引用为.
A)*(a[i]+j)
B)(a+i)
C)*(a+j)
E)a[i]+j
(10)若有以下定义和语句,则对a数组元素地址的正确引用为.
Inta[2][3],(*p)[3]
P=a;
A)*(p+2)
B)p[2]
C)p[l]+l
D)(p+1)+2
第十章结构体与共用体
(1)以下对结构体类型变量的定义中不正确的是
A)#defineSTUDENTstructstudent
STUDENT
{intnum;
floatage;
}stdl;
B)structstudent
{intnum;
floatage;
}stdl;
C)struct
{intnum;
floatage;
}stdl;
D)struct
{intnum;
floatage;
(student;
structstudentstd1;
(2)设有以下语句
(3)structstu
{inta;
floatb;
Jstutype;
则下面叙述正确的是.
A)struct是结构体类型的关键字
B)structstu是用户定义的结构体类型
C)stutype是用户定义的结构体类型名
D)a和b都是结构体成员名
(4)设有以下定义:
structsk
{intn;
floatx;
}data,*p;
若要使p指向data中的n域,正确的赋值语句是
A)p=&data.n;
B)*p=data.n;
C)p=(structsk*)&data.n;
D)p=(structsk*)data.n;
(5)设有以下语句:
structst
{intn;
structst*next;
)
staticstructsta[3]={5,&a[l],7,&a[2],9,,\0,},*p;
p=&a[O];
则以下表达式的值为6的是.
A)p++->n
B)p->n++
C)(*p).n++
D)++p->n
第十一章位运算
(1)以下运算符中优先级最低的是优先级最高的是。
A)&&
B)&
C)||
D)|
(2)若有运算符《,sixeofd&=则它们按优先级按由高到低的正确排列次序是
A)sizeof,&=,«,A
B)sizeof,«,A,&=
C)A,«,sizeof,&=
D)«,A,&=,sizeof
⑶在C语言中,要求运算数必须是整型的运算符是o
A)八
B)%
C)!
D)>
(4)在C语言中,要求运算数必须是整型或字符型的运算符是。
A)&&
B)&
C)!
D)||
(5)sozeof(float)是。
A)一种函数调用
B)一种不合法的表示形式
C)一个整型表达式
D)一个浮点表达式
第十二章文件
⑴系统的标准输入文件是指。
A)键盘
B)显示器
C)软盘
D)硬盘
(2)以下可作为函数fopen中第一个参数的正确格式是。
A)c:user\text.txt
B)c:\user\text.txt
C)"c:\user\text.txt"
D)nc:\\user\text.txtn
(3)若执行fopen函数时发生错误,则函数的返回值是.
A)地址值
B)0
C)1
D)E0F
(4)若要用fopen函数打开一个新的二进制文件,该文件要既能读又能写,则文件方式字符串
应是O
A)nab+”
B)“wb+”
C)Hrb+"
D)nab
(5)当顺利执行了文件关闭操作时,fclose函数的返回值是o
A)-l
B)TURE
C)0
D)1
二、填空
第一章C语言概述
(1)C源程序的基本单位是()
(2)一个C源程序至少应包括一个()
(3)在一个C源程序中,注释部分两侧的分界符分别为()和()
(4)在C语言中,输入操作是由库函数()完成的,输出操作是由库函数()完成的.
第二章数据类型、运算符与表达式
⑴在C语言中(以16位机为例),一个char型数据在内存中所占的字节数为(),一个int型
数据在内存中所占的字节数为()。
(2)在C语言中,实型变量分为两种类型,它们是()和()。
⑶若a是int型变量,则计算表达式a=25/3%3后,a的值为()。
(4)C语言中的标识符只能由三种字符组成,它们是(),()和()
(5)表达式8/4*(int)2.5/(int)(1.25*3.7+2.3)值的数据类型为()。
第三章简单C程序设计
(1)以下程序的输出结果是()。
main()
{intx=l,y=2;
printf("x=%dy=%d*sum*=%d\n”,x,y,x+y);
printf(''10squaredis:%d\n”,10*10);
)
(2)以下程序的输出结果是()。
#include<studo.h>
main()
{inta=325;doublex=3.1415926;
printf("a=%+06dx=%+e\n,,,a,x,);
)
(3)假设变量a和b均为整型,以下语句可以下借助任何变量把a、b中的值进行交换。请填空。
a+=();b=a-();a-=();
(4)设x,y和z都是int型变量,m为long型变量,则在16位微型机上执行下面的赋值语句后,x
值为(),y值为(),z值为()。
y=(x=32767,x=-l);
z=m=0xFFFF
(5)若x为int型变量,则执行以下语句后x的值是()
x=7;
x+=x-=x+x;
第四章选择结构程序设计
(1)当a=3,b=2,c=l时,表达式f=a>b>c的值是()。
(2)在C语言中表示逻辑“真”值用()。
(3)设x,y,z均为int型变量,请写出描述“x或y中有一个小于z”的表达式().
(4)当m=2,n=l,a=l,b=2,c=3时,执行完d=(m=a!=b)&&(n=b>c)Jp;n的值为(),m的值为
()o
(5)Winta=3,b=4,c=5;则表达式a||b+c&&b=二c的值为()。
第五章循环控制
(1)执行下面程序段后,K值是()。
K=l;n=263;
Do{k*=n%10;n/=10)while(n);
(2)下面程序段中循环体的执行次数是()o
A=10;
B=0;
Do{b+=2;a-=2+b;}while(a>=0);
(3)下面程序段的运行结果是()。
X=2'
Do{printf("*");x—;}while(!x==0);
(4)下面程序段的运行结果是()o
1=1;a=0;s=l;
Do{a=a+s*i;s=-s;i++;}while(i<=10)
Printf(,=%d,a");
(5)鸡兔共有30只,脚共有90个,下面程序段是计算鸡兔各有多少只,请填空。
For(x=l;x<=29;x++)
{y=30-x;
if()printf(U4%d,%d\n”,x,y);
第六章数组
(1)在c语言中,二维数组的定义方式为:类型说明符数组名()();
(2)在C语言中,二维数组元素在内存中的存放顺序是()。
(3)若有定义:doublex[3][5];则x数组中行下标的下限为(),列下标的上限为()。
(4)若二维数组a有m歹U,则计算机任一元素a口①在数组中位置的公式为:().(假设a[0][0]
位于数组的第一个位置上。)
(5)若有定义:血2网[4]={{1,2},{0},{4,6,8,10}};则初始化后,a⑴⑵得到的初值是(),a[2][l]
得到初值是()。
第七章函数
(l)C语言规定,可执行程序的开始执行点是()。
(2)在C语言中,一个函数一般由两个部分组成,它们是()和()。
(3)下面add函数的功能是求两个参数的和,并将和值返回调用函数。函数中错误的部分是();
改正后为()。
Voidadd(floata,floatb)
{floatc;
c=a+b;
returnc'
)
(4)以下程序的运行结果是()。
main()
{increment();
increment();
increment();
increment();
{intx=0;
x+=l;
printfC4%d,\x);
)
(5)以下Check函数的功能是对value中的值进行四舍五入计算,若计算后的值与ponse值相等,
则显示“WELLDONE!!”,否则显示计算后的值。已有函数调用语句Check(ponse,value);请填空。
VoidCheck(intponse,value)
{intval;
val=();
printf("计算后的值:%d”,val);
if()printf(4t\NwellDNOE!!!\n");
elseprintf)”\nSorrythecorrectansweris%d\n,,,val);
)
第八章编译预处理命令
(1)设有以下宏定义:#defineWIDTH80
#defineLENGTHWIDTH+40
则执行赋值语句:v=LENGTH*20;(V为int型变量诟,v的值是()。
(2)设有以下宏定义:#defineWIDTH80
#defineLENGTH(WIDTH+40)
则执行赋值语句:k二LENGTH*20;(K为ini型变量)后,k的值是()。
(3)下面程序的运行结果是()o
#defineDOUBLE(r)r*r
main()
{intx=l,y=2,t;
t=DOBLE(x+y);
priiuf("%d\n”,t);
)
(4)下面程序的运行结果是()。
#defineMUL(z)(z)*(z)
main()
(
printfC6%d\n,5,MUL(l+2)+3);
)
(5)下面程序的运行结果是()o
#definePOWER(x)((x)*(x))
main()
{int1=1;
while(I<=4)printf("%d\t”,POWER(I++));
printf(“\n”);
)
第九章指针
(1)下面程序段的运行结果是()
chars[80],*sp=,,HELLO!n;
sp=strcpy(s,sp);
s[O]='h,;
puts(sp);
(2)下面程序段的运行结果是()
char[a]=,,123456789)),*p;
int1=0;
p=a;
while(*p)
{if(I%2==0)p='*';
p++;I++;
)
puts(a);
(3)若有以下语句和定义:
inta[4]={0,l,2,3,},*p;
p=&a[l];
则++(*p)的值是()
(4)若有定义:inta[2][3]={2,4,6,8,10,12}^U(&a[0][0]+282+l的值是(),*(a[l]+2)的值是()。
第十章结构体与共用体
(1)以下程序用以输出结构体变量bt所占内存单元的字节数,请在。内填上适当的内容。
Structps
{doubleI;
chararr[20];
)
main()
{structpsbt;
ptintf(4Cbtsize:%d\n:,());
(2)设有三人的姓名和年龄存在结构数组中,以下程序输出三人中年龄居中者的姓名和年龄,请
在()内填上正确的内容。
Staticstructman
{charname[20]
intage;
}person口{“li—ming,,,l8,
“wang—hua”,19,
“zhang—ping”,20
);
main()
{inti,j,max,min;
max=min=person[0].age;
for(i=l;i<3;i++)
if(person[i].age>max)();
elseif(person[i].age<min)();
for(i=0;i<3;i++)
if(person[i].age!=max()person[i].age!=min)
{printf(u%s%d\n,,,person|i].name,person[i].age);
break;
)
(3)若以定义:
structnum
{inta;
intb;
floatf;
}n={l,3,5.0};
structnum*pn=&n;
则表达式pn->b/n.a*++pn->b的值是(),表达式(*pn).a+pn->f的值是
()o
(4)以下程序的功能是计算并打印复数的差。请在()内填入正确的内容。
Structcomp
{floatre;
floatim;
)
structcomp*m(x,y)
structcomp*x,*y;
{();
z=(structcomp*)malloc(sizeof(structcomp));
z->re=x->re-y->re;
z->im=x->im-y->im;
return(());
)
main()
{structcomp*t;
structxompa,b;
a.re=l;a.im=2;
b.re=3;b.im=4;
t=m(());
printf(44z.re=%f,z.im=%f\t->re,t->im);
)
(5)以下程序的运行结果是()
structks
{inta;
int*b;
}s[4],*p;
main()
(
intn=l,i;
printf("\n”);
for(i=0;i<4;i++)
{s[i].a=n;
s[i].b=&s[i.a;
n=n+2;
)
p=&sfO];
p++;
printf(44%d,%d\n”,(++p)>a,(p++)・>a);
第十一章位运算
(1)在c语言中,&运算符作为单目运算符时表示的是()运算;作为双目运算符时表示
的是()运算。
(2)与表达式a&=b等价的另一书写形式是()。
(3)设有chara,b;若要通过a&b运算屏蔽掉a中的其它位,只保留第2和第8位(右起为第1位),
则b的二进制数是().
(4)测试char型变量a第六位是否为1的表达式是()(设最右位是第一位)。
(5)设二进制数x的值是11001101,若想通过x&y运算使x中的低4位不变,高4位清零,则y的
二进制数为()。
第十二章文件
(1)在C程序中,文件可以用()方式存取,也可以用()方式存取。
(2)在C程序中,数据可以用()和()两种代码形式存放。
(3)在C程序中,文件的存取是以()为单位的,这种文件被称作()文件。
(4)函数调用语句:fgets(buf,n,fp);从fp指向的文件中读入()个字符放到buf字符数组中。
函数值为()。
(5)feof(fp)函数用来判断文件是否结束,如果遇到文件结束,函数值为(),否则为()。
三、判断
第一章C语言概述
第二章数据类型、运算符与表达式
(1)C语言所提供的基本数据类型包括:整型、实型和字符型。
(2)在C程序中,逗号运算符的优先级最低。
(3)当从键盘输入数据时,对整型变量只能输入整型数据,对实型变量只能输入实型数据。
(4)C语言中的标识符只能由字母、数字和下划线三种字符组成。
(5)在C语言中,char型的数据在内存中的存储形式是原码形式。
第三章简单C程序设计
(1)当输入一个实型数据时,格式控制部分应规定小数点后的位数,如scanf(“%4.2E,&f)。
(2)整型变量的输出格式控制符只有%d一种。
(3)putchar函数可以向终端输出一个字符串。
(4)pirntf函数中用到格式符%5s,其中数字5表示输出的字符串占5歹ij,如果字符串长度大
于5,则输出按原字符长度从左向右全部输出。
(5)输入项可以是一个实型常量,如scanf("%F',2.3)。
第四章选择结构程序设计
(1)逻辑运算符两侧的运算对象可以是任何基本类型的数据。
(2)C语言中只提供了三种逻辑运算符:&&,和!。
(3)若a=6,b=4,c=3则表达式a&&b+c||b-c的值是0。
(4)关系运算式的结果都是逻辑值。
(5)若a=l,b=2,则表达式a>b?a:b+l的值是3。
第五章循环控制
(1)设有以下程序段:
intx=0,s=0;
while(!x!=0)s+=++x;
printf("%d”,s);
则运行该程序段后输出为:0
(2)for循环只能应用于循环次数已经确定的情况。
(3)goto语句只能用于退出多层循环。
(4)switch语句中不能出现continue语句。
(5)只能用continue语句终止本次循环。
第六章数组
(1)两个字符串中所包含的字符个数相同时,才能比较字符串。
(2)字符数组可以存放字符串。
(3)不能用关系运算符对字符数组中的字符串进行比较。
(4)如果定义了一个指向数组的指针,则该指针可以相当于数组名使用。
(5)如果没有给一个整型数组的元素赋初值,则其元素的缺省初值全部为0。
第七章函数
(1)C语言中,用户若需调用标准库函数,在调用前必须重新定义。
(2)C语言中不允许用户重新定义标准库函数。
(3)在C程序中,函数的定义和调用都不允许嵌套。
(4)如果用数组名作为函数调用的实际参数,则传递给形参的是数组的首地址。
(5)形式能参数也是一种局部变量。
第八章编译预处理命令
(1)预处理命令行都必须以#号开始。
(2)宏替换不占用运行时间,只占编译时间。
(3)C程序在执行过程中对预处理命令进行处理。
(4)宏名必须用大写字母表示。
(5)在文件包含预处理命令的使用形式中,当#include后的文件名用<>括起来时,表示在
当前目录搜索被包含文件。
第九章指针
(1)若有定义:int(*p)[4],则标识符p表示的是一个指向整型变量的指针。
(2)若有定义:int*p[4J,则标识符p表示的是一个指针数组名•
(3)指针值就是地址值。
(4)若有定义int(*p)(),指针p可以表示函数返回值的类型。
(5)C语言允许main函数带形参,但形参名只能是argv和arvc。
第十章结构体与共用体
(1)当定义一个结构体变量时,系统分配给它的内存是各成员所需内存量的总和。
(2)C语言中,结构体变量在程序执行期间只有部分成员驻留在内存中。
(3)一个共用体类型定义中不能出现结构体类型的成员。
(4)用typedef只是将已存在的类型用一个新的标识符来代表,而不能增加新类型。
(5)用typedef可以定义各种类型名,但不能用来定义变量。
第十一章位运算
第十二章文件
(1)利用fseek函数可以实现文件的随机读写的操作。
(2)函数rewind的作用是使位置指针重新返回文件的开头。
(3)在C程序中,文件可以用随机读写的方式存取,也可以用顺序读写的方式存取。
(4)函数ftell(fp)的作用是得到流式文件中的当前位置。
(5)fgetc函数的作用是从指定文件读入一个字符,该文件的打开方式必须是只读的。
四、程序设计
第一章C语言概述
第二章数据类型、运算符与表达式
第三章简单C程序设计
第四章选择结构程序设计
(1)编程实现:输入一个整数,判断它能否被子3,5,7整除,并输出以下信息之一:
1)能同时被3,5,7整除;
2)能被其中两数(要指出哪两个)整除;
3)能被其中一个数(要指出哪一个)整除;
4)不能被3,5,7任一个整除。
(2)用switch编程实现:
r-1(x<0)
y=0(X=0)
1(X.O)
第五章循环控制
(1)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论