1~5CBCBD 6~10BDBDA 11~15DCDAA 16C
解释:1标识符可以是字母,数字,下划线,但作为变量只能是字母和下划线为开头的。(注意 —,- 两个是不一样的)
2struct 是结构体的标志 union是共用体的标志 注意二者的相同和不同
5scanf函数要按照“”里面的原样输入 printf函数按“”里面的原样输出
6 AP+9 表示取指针变量的值然后加9 B. (P+8) 表示取p指针往后数8个地址(元素)的值 C. P+=9 相当于P=P+9 和A答案的结果一样 但过程和效果很大差别 D. P+8表示地址往后数8个 既指针变量变了
7 z=x>yx+y:x-y; 可以根据运算符的级别计算先后 里面有条件运算符和赋值运算符 条件运算符级别高于赋值运算符(在所有的运算符里面最低) x>Y是不成立的 那么就取X—Y赋给Z
10和7题相似 考查运算符的级别高低 b=a<c ; 里面有逻辑运算和赋值运算 逻辑运算结果就只有0(表示假的)1(表示真的)
11考查的和10 7 一样的思想 不过要注意里面运算符的高低和结合性
12要知道那个If和那个ELSE结合 有一个原则 就是ELSE总是和(最近的一个没有别人结合的IF)结合 实际上是这样的
if(a>b)
{ if(a<c) x=1;
else x=2;}
esle x=3;
哪里还不懂的发来 要是有错的告诉我一声 谢谢
这个貌似没有正确答案啊!
A:第一句,将较大的数赋给了t,然后第二句,又将s赋给了t。所以错误。
B:第一句,将u赋给t,而第二句,说明如果t不为零的话,将s赋给t
C:将较小的数赋给了t
D:第一句,将s赋给了t,第二句说明如果t不为零的话,将u赋给t。
1.一个C程序的执行是从( A )。
A) 本程序的main函数开始,到main函数结束
B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束
C) 本程序的main函数开始,到本程序文件的最后一个函数结束
D) 本程序文件的第一个函数开始,到本程序的main函数结束
2.以下叙述正确的是( C )。
A) 在C程序中,main函数必须位于程序的最前面
B) C程序的每行中只能写一条语句
C) C语言本身没有输入输出语句
D) 在对一个C程序进行编译的过程中,可发现注释中的拼写错误
3.以下叙述不正确的是( D )。
A) 一个C源程序可由一个或多个函数组成
B) 一个C源程序必须包含一个main函数
C) C程序的基本组成单位是函数
D) 在C程序中,注释说明只能位于一条语句的后面
4.C语言规定,在一个源程序中,main函数的位置( C )。
A) 必须在最开始 B) 必须在系统调用的库函数的后面
C) 可以任意 D) 必须在最后
5.一个C语言源程序是由( B )。
A) 一个主程序和若干子程序组成 B) 函数组成
C) 若干过程组成 D) 若干子程序组成
二 填空题
1.C源程序的基本单位是 函数 。
2.一个C源程序中至少应包括一个 main函数 。
3.在一个C源程序中,注释部分两侧的分界符分别为 / 和 / 。
4.一个函数是由两部分组成的,它们分别是 函数名 和 函数体 。
5.在C语言中,一个函数的函数体一般包括 声明部分 和 执行部分 。
第三章 数据类型、运算符与表达式
一 单项选择题
1.下面四个选项中,均不是c语言关键字的选项是( A )。
A) define IF Type B) getc char printf
C) include scanf case D) while go pow
2.C语言中的标识符只能由字母、数字和下划线三种字符组成,且第一个字符( C )。
A) 必须为字母 B) 必须为下划线
C) 必须为字母或下划线 D) 可以是字母、数字和下划线中任一种字符
3.下列四个选项中,均是C语言关键字的选项是( B )。
A) auto enum include B) switch typedef continue
C) signed union scanf D) if struct type
4.下面四个选项中,均是不合法的用户标识符的选项是( C )。
A) A P_0 do B) float la0 _A
C) b-a goto int D) _123 temp int
5.以下有4组用户标识符,其中合法的一组是( C )。
A) For -sub Case B) 4d DO Size
C) f2_G3 IF abc D) WORD void define
二 填空题
1.若x和a均是int型变量,则计算表达式(1)后的x值为 12 ,计算表达式(2)后的x值为 4 。
(1) x=(a=4, 62)
(2) x=a=4, 62
2.若a是int型变量,则表达式(a=45, a2), a+6的值为 26 。
3.若b是int型变量,则表达式b=25/3%3的值为 2 。
4.若s是int型变量,且s=6 则下面表达式s%2+(s+1)%2的值为 1 。
5.若a,b和c均是int型变量,则计算表达式a=(b=4)+(c=2)后,a值为 6 ,b值为 4 ,c值为 2 。
6.若x和n均是int型变量,且x和n的初值均为5,则计算表达式x+=n++后x的值为 10 ,n的值为 6 。
7.若有定义:int b=7;float a=25,c=47;则表达式a+(int)(b/3(int)(a+c)/2)%4的值为 45 。
8.若有定义:int a=2,b=3;float x=35,y=25;则表达式(float)(a+b)/2+(int)x%(int)y的值为 35 。
9.若有定义:int x=3,y=2;float a=25,b=35;则表达式(x+y)%2+(int)a/(int)b的值为 1 。
10.若x和n均是整型变量,且x的初值为12,n的初值为5,则计算表达式x%=(n%=2)后x的值为 0 。
第四章 最简单的C程序设计——顺序程序设计
一 单项选择题 1~5 BDDAB
1.printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列,如果字符串长度大于5,则输出按方式( B )。
A) 从左起输出该字符串,右补空格
B) 按原字符长从左向右全部输出
C) 右对齐输出该字串,左补空格
D) 输出错误信息
2.已有定义int a= -2; 和输出语句 printf(“%8x”,a); 以下正确的叙述是( D )。
A) 整型变量的输出形式只有%d一种
B) %x是格式符的一种,它可以适用于任何一种类型的数据
C) %x是格式符的一种,其变量的值按十六进制输出,但%8x是错误的
D) %8x不是错误的格式符,其中数字8规定了输出字段的宽度
3.若x, y均定义成int型,z定义为double型,以下不合法的scanf函数调用语句是
( D )。
A) scanf(“%d %x, %le”, &x, &y, &z);
B) scanf(“%2d %d, %lf”, &x, &y, &z);
C) scanf(“%x %d %o”, &x, &y);
D) scanf(“%x %o%62f”, &x, &y, &z);
4.以下程序的输出结果是( D )。
main( )
{ int k=17;
printf("%d,%o,%x\n",k,k,k);
}
A)17,021,0x11 B)17,17,17
B)17,0x11,021 D)17,21,11
5.下列程序的运行结果是( B )。
#include <stdioh>
main()
{ int a=2,c=5;
printf("a=%d,b=%d\n",a,c);
}
A) a=%2,b=%5 B) a=2,b=5
C) a=d,b=d D) a=2,c=5
二 填空题
1.下面程序的运行结果是 i:dec=4,oct=4,hex=4,unsigned=65531 。
main()
{
short i;
i= -4;
printf(“\ni: dec=%d, oct=%o, hex=%x, unsigned=%u\n”, i, i, i, i);
}
2.若想通过以下输入语句使a=50,b=4,c=3,则输入数据的形式应该是 50,4,c=3 。
int b,c; float a;
scanf("%f,%d,c=%d",&a,&b,&c);
3.下列程序的输出结果是1600,请填空。
main()
{ int a=9, b=2;
float x= 66 , y=11,z;
z=a/2+bx/y+1/2;
printf("%52f\n", z );
}
4.在printf格式字符中,只能输出一个字符的格式字符是 c ;用于输出字符串的格式字符是 s ;以小数形式输出实数的格式字符是 f ;以标准指数形式输出实数的格式字符是 e 。
三 编程题
1 若a=3, b=4, c=5, x=12, y=24, z= -36, u=51274, n=128765, c1=’a’, c2=’b’。想得到以下的输出格式和结果,请写出完整的程序(包括定义变量类型和设计输出)。
要求输出的结果如下:
a= <空格>3 <空格><空格> b= <空格> 4<空格><空格> c= <空格>5
x=1200000, y=2400000, z= -3600000
x+y=<空格>360<空格><空格> y+z = -120<空格><空格>z+x= -240
u=<空格>51274<空格><空格>n=<空格><空格><空格>128756
c1= a <空格>or<空格>97(ASCII)
c2= B <空格>or<空格>98(ASCII)
/
void main()
{
int a, b, c;
unsigned u;
long int n;
float x, y, z;
char c1,c2;
a=3, b=4, c=5, x=12, y=24, z= -36, u=51274, n=128765, c1='a', c2='b';
printf("a=%2d b=%2d c=%2d\n", a, b, c);
printf("x=%f, y=%f, z=%+f\n");
printf("x+y=%52f y+z =%+52f z+x=%+52f\n", x+y, y+z, z+x);
printf("u=%6d n=%9d\n");
printf("c1=%c or %d(ASCII)\n", c1, c1);
printf("c2=%c or %d(ASCII)\n", c2-32, c2);
}
/
2 输入一个华氏温度,要求输出摄氏温度。公式为
输出要有文字说明,取2位小数。
/
void main()
{
float c, f;
printf("输入一个华氏温度:\n");
scanf("%f", &f);
c = 50/90(f-32);
printf("\n输入的华氏温度 %2f,摄氏温度为: %2f\n", f, c);
}
/
3 编程序,用getchar函数读入两个字符给c1、c2,然后分别用putchar函数和printf函数输出这两个字符。
/
void main()
{
char c1, c2;
c1 = getchar();
c2 = getchar();
putchar(c1);
putchar(c2);
printf("\nc1 = %c; c2 = %c\n", c1, c2);
}
/
第五章 选择结构程序设计
一 单项选择题
1.逻辑运算符两侧运算对象的数据类型是( D )。
A) 只能是0或1
B) 只能是0或非0正数
C) 只能是整型或字符型数据
D) 可以是任何类型的数据
2.已知x=43, ch='A', y=0;则表达式(x>=y&&ch<'B'&&!y)的值是( C )。
A) 0 B) 语法错 C) 1 D) “假”
3.已知 int x=10, y=20, z=30; 以下语句执行后x, y, z的值是( B )。
if(x>y)
z=x;x=y;y=z;
A) x=10,y=20,z=30 B) x=20,y=30,z=30
C) x=20,y=30,z=10 D) x=20,y=30,z=20
4.执行下列语句后a的值为( 2 ),b的值为( 1 )。( C )
int a, b, c;
a=b=c=1;
++a|| ++b && ++c;
A) 错误 1 B) 2 2 C) 2 1 D) 1 1
5.若希望当A的值为奇数时,表达式的值为“真”,A的值为偶数时,表达式的值为“假”,则以下不能满足要求的表达式是( C )。
A) A%2==1 B) !(A%2==0) C) !(A%2) D) A%2
二 填空题
1.若从键盘输入58,则以下程序输出的结果是 585858 。
main()
{ int a;
scanf(“%d”,&a);
if(a>50) printf(“%d”,a);
if(a>40) printf(“%d”,a);
if(a>30) printf(“%d”,a);
}
2.下面程序的运行结果是 -1 。
main()
{
int a=2, b=3, c;
c=a;
if(a>b) c=1;
else if(a==b) c=0;
else c=-1;
printf(“%d\n”,c);
}
3.以下程序实现:输入三个整数,按从大到小的顺序进行输出。请填空。
main()
{
int x, y, z, c;
scanf(“%d %d %d”, &x, &y, &z);
if( x<y )
if( x<z )
if( y<z )
printf(“ %d %d %d”, x, y, z);
}
4.如果运行时输入字符Q,则下面程序的运行结果是 Q 。
main()
{
char ch;
scanf(“%c”, &ch);
ch=(ch>=‘A’&& ch<=‘Z’) (ch+32):ch;
ch=(ch>=‘a’&& ch<=‘z’) (ch-32):ch;
printf(“%c”, ch);
}
5.若x为int类型,请以最简单的形式写出与逻辑表达式!x等价的C语言关系表达式 x==0 。
第六章 循环控制
一 单项选择题
1.下面程序段的运行结果是( C )。
int n=0;
while(n++<=2);
printf(“%d”,n);
A) 2 B) 3 C) 4 D) 有语法错
2.设有程序段:
t=0;
while(printf(“”))
{t++;
if(t<3) break;
}
下面描述正确的是( D )。
A) 其中循环控制表达式与0等价
B) 其中循环控制表达式与'0'等价
C) 其中循环控制表达式是不合法的
D) 以上说法都不对
3.下面程序的功能是将从键盘输入的一对数,由小到大排序输出,当输入一对相等数时结束循环,请选择填空( B )。
#include <stdioh>
main()
{int a,b,t;
scanf(“%d%d”,&a,&b);
while( ___________ )
{if(a>b)
printf(“%d,%d\n”,a,b);
scanf("%d%d",&a,&b);
}
}
A) !a=b B) a!=b C) a==b D) a=b
4.C语言中,while和do-while循环的主要区别是( A )。
A) do-while的循环体至少无条件执行一次
B) while的循环控制条件比do-while的循环控制条件更严格
C) do-while允许从外部转到循环体内
D) do-while的循环体不能是复合语句
5.对以下程序段描述正确的是( C )。
x=-1;
do
while(!x);
A) 是死循环 B) 循环执行二次
C) 循环执行一次 D) 有语法错误
二 填空题
1.以下程序运行后的输出结果是 52 。
main()
{ int i=10, j=0;
do
while(i>2);
printf("%d\n",j);
}
2.设有以下程序:
main()
{ int n1,n2;
scanf("%d",&n2);
while(n2!=0)
{ n1=n2%10;
n2=n2/10;
printf("%d",n1);
}
}
程序运行后,如果从键盘上输入1298,则输出结果为 8921 。
3.若输入字母b,程序输出结果为 b, B ;若输入字符,程序将怎样 等待重新输入 。
#include<stdioh>
main()
{char c1, c2;
c1=getchar();
while(c1<97||c1>122)
c1=getchar();
c2=c1-32;
printf("%c, %c\n",c1, c2);
}
4.用以下程序计算1到100的整数的累加和。
main()
{ int i=1, sum= 0 ;
for( ; i<=100 ; )
{sum+=i;
i++;
}
printf("sum=%d\n", sum );
}
5.以下程序的功能是:从键盘上输入若干个学生的成绩,统计并输出最高成绩和最低成绩,当输入负数时结束。请填空。
main()
{ float x, amax, amin;
scanf(“%f”,&x);
amax=x;
amin=x;
while( x>=0 )
{if(x>amax) amax=x;
if( x<amin ) amin=x;
scanf(“%f”,&x);
}
printf("amax=%f\namin=%f\n",amax, amin);
}
考试试卷(F卷)
——标 准 答 案
计算机程序设计 课程 56 学时 35 学分 考试形式: 闭 卷
一、选择题(15小题,每小题2分,共计30分)
1下面不正确的字符串常量是 A 。
A)'abc' B)"12'12" C)"0" D)" "
2.以下正确的叙述是 D
A)在C程序中,每行中只能写一条语句
B)若a是实型变量,C程序中允许赋值a=10,因此实型变量中允许存放整型数
C)在C程序中,无论是整数还是实数,都能被准确无误(精确)地表示
D)在C程序中,%是只能用于整数运算的运算符
3.已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2='A'十'6'一'3';后,c2中的值为 A
A)D B)68 C)不确定的值 D)C
4.sizeof(float)是 B :
A)一个双精度型表达式 B)一个整型表达式
C)一种函数调用 D)一个不合法的表达式
5以下说法正确的是 D :
A)输入项可以为一实型常量,如scanf("%f",35);
B)只有格式控制,没有输入项,也能进行正确输入,如scanf("a=%d,b=%d");
C)当输入一个实型数据时,格式控制部分应规定小数点后的位数,如scanf("%42f",&f);
D)当输入数据时,必须指明变量的地址,如scanf("%f",&f);
6.已有如下定义和输入语句,若要求a1,a2,c1,c2的值分别为10,20,A,B,当从第一列开始输入数据时,正确的数据输入方式是 D (注: 表示回车)。
int a1,a2; char c1,c2;
scanf("%d%d",&a1,&a2); scanf("%c%c",&c1,&c2);
A) 1020AB B)10 20 AB
C)10 20 AB D)10 20AB
7请阅读以下程序:
void main()
{int a=5,b=0,c=0;
if(a=b+c) printf(" ");
e1se printf("$$ ");
以上程序 D :
A)有语法错不能通过编译 B)可以通过编译但不能通过连接
C)输出 D)输出$$
8下面程序段的运行结果是 C 。
x=y=0;
while(x<15) {y++;x+=++y;}
printf("%d,%d",x,y);
A)20,7 B)6,12 C)20,8 D)8,20
9若有说明:int a[3]={0};则下面正确的叙述是 D 。
A) 只有元素a[0]可得到初值0
B) 此说明语句不正确
C) 数组a中各元素都可得到初值,但其值不一定为0
D) 数组a中每个元素均可得到初值0
10在c语言中,引用数组元素时,其数组下标的数据类型允许是_ C _。
A)整型常量 B)整型表达式
C)整型常量或整型表达式 D)任何类型的表达式
11下面程序段的运行结果是 _ B _。
char c[5]={'a','b','','c',''};
printf("%s",c);}
A)’a’’b’ B)ab C)ab c D)a b
12以下叙述正确的是 C 。
A) 在C程序中,main函数必须位于程序的最前面
B) C程序的每行中只能写一条语句
C) C语言本身没有输入输出语句
D) 在对一个C程序进行编译的过程中,可发现注释中的拼写错误
13.简单变量做实参时,实参与其对应的形参之间的数据传递方式是 C 。
A)双向值传递方式 B)地址传递方式
C)单向值传递方式 D)用户指定传递方式
14编辑程序的功能是 A 。
A)修改并建立源程序 B)将源程序翻译成目标程序
C)调试程序 D)命令计算机执行指定的程序
15在C语言中,5种基本数据类型的存储空间长度排列顺序为 C。
A)char<int<1ong int<="float<double </int
C)char<int<=1ong d)char="int=1ong" int<="float<double </int
二、计算表达式(每小题15分,共计15分):
设 int x=25,y=-20;float a=10256,b=5087;(注意:各式结果不影响后续的题目!)
1.(++y)+(x--) ( 6 )
2.y=y+=25 ( 25 )
3.x+y>=0(x-2y):(x+2y) ( 65 )
4.(x+y)/2+(int)(a-b)%(int)b ( 3 )
5.x/2+(a-b)/2 ( 37845 )
6.!(x=a)&&(y=b)&&1 ( 0 )
7.!(a+b-1)||y+x/2 ( 1 )
8.计算(y>=0)&&(++y)后y的值为: ( -20 )
9.printf(“%d”,’102’);结果为 ( 66 )
10.已知’a’的ASCII码为97,则:printf(“%c”,’d’);结果为( d )
三、写出下列程序的的执行结果(每小题5分,共计20分,注意输出格式)
1.#include
Int main()
{ int a=23389,b=45;float x=6473586,y=136435538;
char c1=’A’,c2[]="Hello";
printf("a=%4d,b=%4d ",a,b);
printf("%-92f,%92f ",x,y);
printf("%o,%x,%u ",b,b,b);
printf("%d,%c ",c1,c1);
printf("%s,%64s ",c2,c2);
return 0;
}
2.#include
#define N 10
int main( )
{ int a=1,b=0, i;
for (i=0; i<n span="" i++)
{ printf("%6d%6d",a,b);
printf(" ");
a=b+a;
b=a+b;}
return 0;}
3.#include
int main()
{ int i,j,k=0;
for(i=1;i<31;i++)
{ for(j=2;j<=i-1;j++)
if(i%j==0) break;
if(j==i)
{ printf("%7d",i) ;
k++;
if(k%2==0) printf(" ");
}
}
Return 0;
}
4.#include
int main()
{ int i=16,j,x=6,y,z;static char c[]=”I am a student”;
j=i+++1; printf(“%5d ”,j);
x=i=j; printf(“%5d ”,x);
x=1,y=2,z=3;
x+=y+=z;
printf(“%5d ”,(z+=x)>y z++:y++);
x=y=z=-1;
++x||++y||z++;
printf(“%5d,%5d,%5d ”,x,y,z);
printf(“%s,%54s ”,c,c);
return 0;
}
四、程序填空(每空15分,共计15分)
1下面程序的功能是:将字符数组s2中的全部字符拷贝到字符数组s1中,不用strcpy函数。
#include
main()
{ char s1[80], s2[80];
int i;
printf("input s2:");
gets(s2) ;
for(i=0;s2[i]!=’’; i++ )
s1[i]=s2[i] ;
s1[i]=’’;
printf("s1: %s ",s1);
return 0;
}
2.输入20个整数,找出其中的最大数及最小数,并求其和值。
#include
int main()
{ int a[20],i,max,min,sum;
printf("input a[0]-a[19]:");
for(i=0;i<20;i++)
scanf(“%d”, &a[i] );
max=a[0]; min=a[0]; sum= a[0] ;
for(i=1; i<20 ;i++)
{ if(a[i]>max) max=a[i];
if(a[i]<min) span="" min=a[i] ;
sum+=a[i];
}
printf(%d,%d,%d ",max,min,sum);
return 0;
}
3.输入一行字符到字符数组中,将其中的小写字母转化成大写字母,大写字母转化成小写字母,然后输出。
#include
#include
main()
{ char c,str[80];
int i;
gets(str);
for(i=0;(c=str[i])!= ’’ ;i++)
{ if( c>=’A’&&c<=’Z’ ) c=c+32;
else if(c>=’a’&&c<=’z’) c=c-32;
str[i]=c; }
puts( str );
return 0;
}
五、编写程序(每小题10分,共计20分)
(注意:可做在试卷反面)
1.输出100到300之间能被5整除却不能被3整除的所有数之和。
#include
int main()
{ int n,sum=0;
for(n=100; n<=300; n++)
if(n%5==0 && n%3!=0) sum += n;
printf(“%d ”, sum);
return 0;
}
2.编写main函数及一个求x阶乘(x!)的用户自定义函数fun( ),并在主函数中调用该函数求组合数c的值
添加注释,不超过 140 字(可选)
。
#include
int main()
{ long int fun(long int x);
long res, res1, res2, res3,m, n;
scanf(“%ld,%ld”,&m,&n);
res1=fun(m); res2=fun(n); res3=fun(m-n);
res=res1/(res2res3);
printf(“%ld ”,res);
return 0;
}
long int fun(long int x);
{ long int i, res=1;
for(i=2; i<=x; i++)
res = i;
return(res);
}
以上就是关于C语言选择题全部的内容,包括:C语言选择题、c语言问题、C语言:输入两个分数,计算它们的和。用a/b+c/d=x/y的形式。源程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)