【www.gbppp.com--经典美文】
第1题 (2.0分) 题号:97 难度:中 第1章
以下不正确的叙述是()。
A:在C程序中所用的变量必须先定义后使用
B:程序中,APH和aph是两个不同的变量
C:若a和b类型相同,在执行了赋值语句a=b;后b中的值将放入a中,b中的值不变 D:当输入数值数据时,对于整型变量只能输入整型值;对于实型变量只能输入实型值
答案:D
第2题 (2.0分) 题号:204 难度:中 第10章
在下列程序段中,枚举变量c1,c2的值依次是()。
enum color {red,yellow,blue=4,green,white} c1,c2;
c1=yellow;c2=white;
printf("%d,%d\n",c1,c2);
A:1,6
B:2,5
C:1,4
D:2,6
答案:A
第3题 (2.0分) 题号:601 难度:中 第2章
下面四个选项中,均是不合法的浮点数的选项是()。
A:160. 0.12 e3
B:123 2e4.2 .e5
C:-.18 123e4 0.0
D:-e3 .234 1e3
答案:B
第4题 (2.0分) 题号:621 难度:中 第3章
printf函数中用到格式符%5s,其中数字5表示输出的字符串占用
5列,如果字符串长度大于5,则输出按方式()。
A:从左起输出该字符串,右补空格
B:按原字符长从左向右全部输出
C:右对齐输出该字串,左补空格
D:输出错误信息
答案:B
第5题 (2.0分) 题号:694 难度:中 第3章
以下叙述正确的是()。
A:可以把define和if定义为用户标识符
B:可以把define定义为用户标识符,但不能把if定义为用户标识符 C:可以把if定义为用户标识符,但不能把define定义为用户标识符 D:define和if都不能定义为用户标识符
答案:B
第6题 (2.0分) 题号:575 难度:中 第4章 若有条件表达式 (exp)?a++:b--,则以下表达式中能完全等价于
表达式(exp)的是()。
A:(exp==0)
B:(exp!=0)
C:(exp==1)
D:(exp!=1)
答案:B
第7题 (2.0分) 题号:208 难度:中 第4章 下列各m的值中,能使m%3==2&&m%5==3&&m%7==2为真的是()。 A:8
B:23
C:17
D:6
答案:B
第8题 (2.0分) 题号:632 难度:中 第5章 以下叙述正确的是()。
A:do-while语句构成的循环不能用其它语句构成的循环来代替.
B:do-while语句构成的循环只能用break语句退出.
C:用do-while语句构成的循环,在while后的表达式为非零时结束循环. D:用do-while语句构成的循环,在while后的表达式为零时结束循环
答案:D
第9题 (2.0分) 题号:506 难度:中 第5章 以下程序段的输出结果为()。
for(i=4;i>1;i--)
for(j=1;j<i;j++)
putchar('#');
A:无
B:######
C:#
D:###
答案:B
第10题 (2.0分) 题号:617 难度:中 第5章 执行语句 for(i=1;i++<4;); 后变量 i 的值是()。
A:3
B:4
C:5
D:不定
答案:C
第11题 (2.0分) 题号:693 难度:中 第10章 以下各选项企图说明一种新的类型名,其中正确的是()。
A:typedef v1 int;
B:typedef v2=int;
C:typedef int v3;
D:typedef v4: int;
答案:C
第12题 (2.0分) 题号:654 难度:中 第6章 以下不能正确定义二维数组的选项是()。
A:int a[2][2]={{1},{2}};
B:int a[][2]={1,2,3,4};
C:int a[2][2]={{1},2,3};
D:int a[2][]={{1,2},{3,4}};
答案:D
第13题 (2.0分) 题号:556 难度:中 第10章 static struct {int a1;float a2;char a3;}a[10]={1,3.5,'A'};
说明数组a是地址常量,它有10个结构体型的下标变量,采用静态存 储方式,其中被初始化的下标变量是()。
A:a[1]
B:a[-1]
C:a[0]
D:a[10]
答案:C
第14题 (2.0分) 题号:635 难度:中 第6章 若有说明:int a[][3]={1,2,3,4,5,6,7};则a数组第一维的大小是()。 A:2
B:3
C:4
D:无确定值
答案:B
第15题 (2.0分) 题号:671 难度:中 第7章 C语言规定:简单变量做实参时,它和对应形参之间的数据传递方式是()。 A:地址传递
B:单向值传递
C:由实参传给形参,再由形参传回给实参
D:由用户指定的传递方式
答案:B
第16题 (2.0分) 题号:182 难度:中 第7章 执行下面程序后,输出结果是()。
main()
{ a=45,b=27,c=0;
c=max(a,b);
printf("%d\n",c);
}
int max(x,y)
int x,y;
{ int z;
if(x>y) z=x;
else z=y;
return(z);
}
A:45
B:27
C:18
D:72
答案:A
第17题 (2.0分) 题号:211 难度:中 第12章 fgets(str,n,fp)函数从文件中读入一个字符串,以下正确的叙述是()。 A:字符串读入后不会自动加入'\0'
B:fp是file类型的指针
C:fgets函数将从文件中最多读入n-1个字符
D:fgets函数将从文件中最多读入n个字符
答案:C
第18题 (2.0分) 题号:554 难度:中 第12章 从键盘上输入某字符串时,不可使用的函数是()。
A:getchar()
B:gets()
C:scanf()
D:fread()
答案:A
第19题 (2.0分) 题号:471 难度:中 第9章 以下程序段 char *alp[]={"ABC","DEF","GHI"}; int j; puts(alp[1]); 的输出结果是()。
A:A
B:B
C:D
D:DEF
答案:D
第20题 (2.0分) 题号:191 难度:中 第9章 设有说明int (*ptr)[M];其中标识符ptr是()。
A:M个指向整型变量的指针
B:指向M个整型变量的函数指针
C:一个指向具有M个整型元素的一维数组的指针
D:具有M个指针元素的一维指针数组,每个元素都只能指向整型量
答案:C
二、程序填空 共2题 (共计20分)
第1题 (10.0分) 题号:24 难度:中 第1章 功能:对任一整数N(N≠0),它都可以分解成1(或-1)和一些质数(素 数)因子的形式。
例如:当N=150时,可分解成1×2×3×5×5;
当N=-150时,可分解为-1×2×3×5×5。
下边程序能实现这种分解过程。当N=150,输出以下分解结 果:N= 1* 2* 3* 5* 5
#include <stdio.h>
#include <stdlib.h>
main()
{
int n,i,r;
scanf("%d",&n);
if (n==0)
{
printf ("data error \n");
习题一
【习题1-1】C语言源程序最多可能由________________部分组成?
A) 预处理部分 B)变量说明部分
C) 函数原型声明部分 D)函数定义部分
【习题1-2】一个完整的C语言源程序最少必须有_______。
A)若干个主函数 B)若干个函数
C)且只能有一个主函数 D)一个函数
【习题1-3】C语言以函数为源程序的基本单位最主要有利于_______。
A)程序设计结构化 B)程序设计模块化
C)程序设计简单化 D提高程序设计有效性
【习题1-4】要使得C语言编写的程序能够在计算机上运行并得出正确结果,必
须要先经过_______________________________________。
A)编辑和链接 B)编译和链接
C)修改和运行 D运行并输入数据
【习题1-5】选择一个C语言集成开发环境并启动它,然后分别输入【例1-1】、
【例1-2】、【例1-3】的源程序,依次编译、链接、运行,看看能否达到预想的结果?从中了解程序的开发过程。
习题二
一、单项选择题
【习题2-1】 已知’A’的ASCII代码是65,以下程序的输出结果是( ) #include "stdio.h"
main( )
{ int c1=65,c2=66;
printf("%c, %c",c1,c2);
}
A. 因输出格式不合法,输出错误信息 B. 65,66
C. A,B D. 65,66
【习题2-2】若变量已正确定义,要将a和b中的数进行交换,下面不正确的语句组是( )
A. a=a+b,b=a-b,a=a-b; B. t=a,a=b,b=t;
C. a=t,t=b,b=a; D. t=b;b=a;a=t;
【习题2-3】 若k是整型变量,则以下程序段的输出是( )
k=-8567;
printf (“|%d|\n”,k);
A. 输出格式不正确 B. 输出为|008567|
C. 输出为|8567| D. 输出为|-8567|
【习题2-4】下列可作变量的标识符是( )
A. 3rt B. je_c C.$89 D. a+6
【习题2-5】C语言中的标识符只能由字母、数字和下划线三种字符组成,且第一个字符( )
A.必须为字母或下划线 B.必须为下划线
C.必须为字母
D.可以是字母、数字和下划线中的任一种字符
【习题2-6】 C语言并不是非常严谨的算法语言,在以下关于C语言的不严谨的叙述中,错误的说法是( )
A. 大写字母和小写字符的意义相同
B. 有些不同类型的变量可以在一个表达式中运算
C. 在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型
D. 同一个运算符号在不同的场合可以有不同的含义
二、简答题
【习题2-7】 C语言数据类型有哪几类?基本数据类型包括哪几类?
【习题2-8】 C语言中十进制、八进制和十六进制整常量是如何表示的?
【习题2-9】 C语言为什么规定对所用到的变量“先定义,后使用”,这样做有什么好处?
【习题2-10】C语言中的语句有几类?控制语句有哪些?
【习题2-11】 怎样区分表达式和表达式语句?为什么有人称C为表达式语言?
【习题2-12】字符常量与字符串常量有什么区别?
【习题2-13】下面各数用八进制和十六进制数表示:
(1)10 (2)32 (3)75 (4)-617
(5)-111 (6)2483 (7)-28654 (8)21003
三、阅读程序写结果或填空
【习题2-14】写出以下程序的运行结果:
#include<stdio.h>
main()
{
char c1='a',c2='b',c3='c',c4='\101',c5='\116';
printf("a%c b%c\tc%c\tabc\n",c1,c2,c3);
printf("\t\b%c %c\n",c4,c5);
}
【习题2-15】写出以下程序的运行结果:
#include<stdio.h>
main()
{
int n=177;
printf("%o\n",n);
}
【习题2-16】写出以下程序的运行结果:
#include<stdio.h>
main()
{
int a,n=0;
n+=(a=10);
printf("%d\n",a);
}
【习题2-17】写出以下程序的运行结果:
#include <stdio.h>
main()
{
int a=5,b=7;
float x=67.8564,y=-789.124;
char c='A';
long n=1234567;
unsigned u=65535;
printf("%d%d\n",a,b);
printf("%3d%3d\n",a,b);
printf("%f,%f\n",x,y);
printf("%-10f,%-10f\n",x,y);
printf("%8.2f,%8.2f,%.4f,%.4f,%3f,%3f\n",x,y,x,y,x,y);
printf("%e,%10.2e\n",x,y);
printf("%c,%d,%o,%x\n",c,c,c,c);
printf("%ld,%lo,%x\n",n,n,n);
printf("%u,%o,%x,%d\n",u,u,u,u);
printf("%s,%5.3s\n","COMPUTER","COMPUTER");
}
【习题2-18】写出以下程序的运行结果:
#include<stdio.h>
main()
{
int i,j,m,n;
i=8;
j=10;
m=++i;
n=j++;
printf("%d,%d,%d,%d",i,j,m,n);
}
【习题2-19】下面运算表达式的值是:
x+a%3*(int)(x+y)%2/4
设x=2.5,a=7,y=4.7
【习题2-20】下面运算表达式的值是:
(float)(a+b)/2+(int)x%(int)y
设a=2,b=3,x=3.5,y=2.5
【习题2-21】 写出下面赋值表达式运算后a的值,设原来a=12;
(1)a+=a (2) a-=2
(3)a*=2+3 (4) a/=a+a
(5)a%=(n%=2),n 的值等于5 (6)a+=a-=a*=a
【习题2-22】 数学表达式:-5<x<5用C语句如何表达?x>5或x<-5又是如何表达?请写出相应的C语句。
四、编写程序题
【习题2-23】 设圆半径r=1.5,圆柱高h=3,求圆周长、圆面积、圆球表面积(4πR2)、圆球体积(V=4πR³/3)、圆柱体积。用scanf()输入数据,输出计算结果,输出时要求有文字说明,取小数点后2位数字。请编写程序。
5【习题2-24】 输入一个华氏温度,要求输出摄氏温度。公式为c=(F-32),9
输出要有文字说明,取2位小数。
【习题2-25】 编程序,用getchar()函数读入两个字符给cl、c2,然后分别用putchar()函数和printf()函数输出这两个字符。并思考以下问题:
(1)变量c1、c2应定义为字符型或整型?抑或二者皆可?
(2)要求输出c1和c2值的ASCII码,应如何处理?用putchar函数还是printf函数?
(3)整型变量与字符变量是否在任何情况下都可以互相代替?如“char c1,c2;”与“int cl,c2;”是否无条件地等价?
【习题2-26】编写程序,从终端键盘输入圆的半径r,圆柱的高h,分别计算出圆周c1、圆面积cs和圆柱的体积cvz。输出计算结果要求有文字说明,并取小数点后两位数字。
【习题2-27】编写程序,读入一个字母,输出与之对应的ASCII码,输入输出都要有相应的文字提示。
习题三
一、单项选择题
【习题3-1】“基本结构”不具有以下特点( )
A. 只有一个入口,只有一个出口 B. 没有死循环
C. 没有永远执行不到的语句 D. 不允许退出循环
【习题3-2】 在流程图中,菱形框表示的操作是( )
A. 数据的输入输出 B. 程序的开始
C. 条件判断 D. 赋值
【习题3-3】以下程序的运行结果是( )
#include<stdio.h>
main()
{int m=5,n=10;
printf("%d,%d\n",m++,--n);
}
A. 5,9 B.6,9
C. 5,10 D.6,10
【习题3-4】逻辑运算符两侧的数据类型( )
A. 只能是0和1 B. 只能是0或非0正数
C. 只能是整型或字符型数据 D. 可以是任何类型的数据
【习题3-5】下列关系表达式结果为假的是( )
A. 0!=1 B. 2<=8
C. (a=2*2)= =2 D. y=(2+2)= =4
【习题3-6】下列运算符中优先级最低的是( )
A. ?: B. +=
C. >= D. = =
【习题3-7】写出下面各逻辑表达式的值。设a=3,b=4,c=5。 a+b>c&&b==c
a||b+c&&b-c
!(a>b)&&!c||1
!(x=a)&&(y=b)&&0
!(a+b)+c-1&&b+c/2
二、简单题
【习题3-8】什么是算法?算法有哪些特性?从日常生活中举出几个算法的例子。
【习题3-9】算法有哪些描述方法?各有什么优缺点?
【习题3-10】结构化的算法有哪几种结构?试分别描述。
【习题3-11】选择语句和循环语句对条件的判断的标准是什么?(即何值为真、何值为假?)
三、用传统流程图表示求解以下问题的算法。
【习题3-12】有两个瓶子A和B,分别盛放醋和酱油,要求将它们互换(即A瓶原来盛醋,现改盛酱油,B瓶则相反);
【习题3-13】依次将10个数输入,要求将其中最大的数打印出来;
【习题3-14】有三个数a、b、c,要求按大小顺序把它们打印出来;
【习题3-15】求1+2+3+…+100;
【习题3-16】判断一个数n能否同时被3和5整除;
【习题3-17】将100~200之间的素数打印出来;
【习题3-18】求两个数m和n的最大公约数;
【习题3-19】求方程式ax2+bx+c=0的根(a、b、c从键盘输入)。
四、编写程序题
【习题3-20】有一函数
(x1) x y2x-1 (1x10) 3x-11 (x100)
单项选择题:
1.( A )是构成C语言程序的基本单位。
A、函数 B、过程 C、子程序 D、子例程
2.C语言程序从 开始执行。
A) 程序中第一条可执行语句 B) 程序中第一个函数
C) 程序中的main函数 D) 包含文件中的第一个函数
3、以下说法中正确的是( C )。
A、C语言程序总是从第一个定义的函数开始执行
B、在C语言程序中,要调用的函数必须在main( )函数中定义
C、C语言程序总是从main( )函数开始执行
D、C语言程序中的main( )函数必须放在程序的开始部分
4.下列关于C语言的说法错误的是( B ) 。
A) C程序的工作过程是编辑、编译、连接、运行
B) C语言不区分大小写。
C) C程序的三种基本结构是顺序、选择、循环
D) C程序从main函数开始执行
5.下列正确的标识符是(C )。
A.-a1 B.a[i] C.a2_i D.int t
6.下列C语言用户标识符中合法的是( B )。
A)3ax B)x C)case D)-e2 E)union
7.下列四组选项中,正确的C语言标识符是( C )。
A) %x B) a+b C) a123 D) 123
8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。
A、print _3d db8 aBc B、I\am one_half start$it 3pai
C、str_1 Cpp pow while D、Pxq My->book line# His.age
9.C语言中的简单数据类型包括(D )。
A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型
C、整型、字符型、逻辑型 D、整型、实型、字符型
10.在C语言程序中,表达式5%2的结果是
A)2.5 B)2 C)1 D)3
11.如果int a=3,b=4;则条件表达式"a<b? a:b"的值是____。
A) 3 B) 4 C) 0 D) 1
12.若int x=2,y=3,z=4 则表达式x<z?y:z的结果是( B ).
A)4 B)3 C)2 D)0 E)1
13.C语言中,关系表达式和逻辑表达式的值是( B )。
A) 0 B) 0或1 C) 1 D) ‘T‟或‟F‟
14. 下面( D )表达式的值为4.
A) 11/3 B) 11.0/3
C) (float)11/3 D) (int)(11.0/3+0.5)
15.设整型变量 a=2,则执行下列语句后,浮点型变量b的值不为0.5的是(
A.b=1.0/a B.b=(float)(1/a)
C.b=1/(float)a D.b=1/(a*1.0) B )
16. 若“int n; float f=13.8;”,则执行“n=(int)f%3”后,n的值是(A)
A.1 B.4 C.4.333333 D.4.6
17. 以下对一维数组a的正确说明是:
A) char a(10); B) int a[];
C)int k=5,a[k]; D)char a[3]={„a‟,‟b‟,‟c‟};
18.以下能对一维数组a进行初始化的语句是: ( C )
A. int a[5]=(0,1,2,3,4,) B. int a(5)={}
C. int a[3]={0,1,2} D. int a{5}={10*1}
19.在C语言中对一维整型数组的正确定义为 。
A)int a(10); B)int n=10,a[n];
C)int n;a[n]; D)#define N 10
int a[N];
20、已知:int a[10]; 则对a数组元素的正确引用是( D )。
A、a[10] B、a[3.5] C、a(5) D、a[0]
21.若有以下数组说明,则i=10;a[a[i]]元素数值是( B )。
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
A.10 B.9 C.6 D.5
22.若有说明:int a[][3]={{1,2,3},{4,5},{6,7}}; 则数组a的第一维的大小为: ( B
A. 2 B. 3 C. 4 D.无确定值
5 7 D) 3 6 9
23.对二维数组的正确定义是( C)
A.int a[ ] [ ]={1,2,3,4,5,6}; B.int a[2] [ ]={1,2,3,4,5,6};
C.int a[ ] [3]={1,2,3,4,5,6}; D.int a[2,3]={1,2,3,4,5,6};
24.已知int a[3][4];则对数组元素引用正确的是_____
A)a[2][4] B)a[1,3] C)a[2][0] D)a(2)(1)
25.C语言中函数返回值的类型是由决定的.
A)函数定义时指定的类型 B) return语句中的表达式类型
C) 调用该函数时的实参的数据类型 D) 形参的数据类型
26. 在C语言中,函数的数据类型是指( A )
A 函数返回值的数据类型 B. 函数形参的数据类型
C 调用该函数时的实参的数据类型 D.任意指定的数据类型
27. 在函数调用时,以下说法正确的是( B )
A.函数调用后必须带回返回值
B.实际参数和形式参数可以同名
C.函数间的数据传递不可以使用全局变量
D.主调函数和被调函数总是在同一个文件里
28. 在C语言中,表示静态存储类别的关键字是: ( C )
A) auto B) register C) static D) extern
29.未指定存储类别的变量,其隐含的存储类别为( A )。
A)auto B)static C)extern D)register
30. 若有以下说明语句:
struct student )
{ int num;
char name[ ];
float score;
}stu;
则下面的叙述不正确的是: ( D )
A. struct是结构体类型的关键字
B. struct student 是用户定义的结构体类型
C. num, score都是结构体成员名
D. stu是用户定义的结构体类型名
31.若有以下说明语句:
struct date
{ int year;
int month;
int day;
}brithday;
则下面的叙述不正确的是_____.
A) struct是声明结构体类型时用的关键字
B) struct date 是用户定义的结构体类型名
C) brithday是用户定义的结构体类型名
D) year,day 都是结构体成员名
32. 以下对结构变量stul中成员age的非法引用是
struct student
{ int age;
int num;
}stu1,*p;
p=&stu1;
A) stu1.age B) student.age C) p->age D) (*p).age
33.设有如下定义:
struck sk
{ int a;
float b;
}data;
int *p;
若要使P指向data中的a域,正确的赋值语句是 C
A) p=&a; B) p=data.a; C) p=&data.a; D)*p=data.a;
34.设有以下说明语句:
typedef struct stu
{ int a;
float b;
} stutype;
则下面叙述中错误的是( D )。
A、struct是结构类型的关键字
B、struct stu是用户定义的结构类型
C、a和b都是结构成员名
D、stutype是用户定义的结构体变量名
35. 语句int *p;说明了
A)p是指向一维数组的指针
B)p是指向函数的指针,该函数返回一int型数据
C)p是指向int型数据的指针
D)p是函数名,该函数返回一指向int型数据的指针
36.下列不正确的定义是( A )。
A. int *p=&i,i; B.int *p,i;
C.int i,*p=&i; D.int i,*p;
37. 若有说明:int n=2,*p=&n,*q=p,则以下非法的赋值语句是: ( D )
A)p=q B)*p=*q C)n=*q D)p=n
38.有语句:int a[10],;则p的正确定义和初始化。
A)int p=*a; B)int *p=a; C)int p=&a; D)int *p=&a;
39.若有说明语句“int a[5],*p=a;”,则对数组元素的正确引用是( C )。
A.a[p] B.p[a] C.*(p+2) D.p+2
40. 有如下程序
int a[
推荐访问: