首页 > 经典文章 > 经典美文 > c语言习题及答案

c语言习题及答案

时间:2018-07-30   来源:经典美文   点击:

【www.gbppp.com--经典美文】

c语言习题及答案 第一篇_C语言习题及答案

第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");

c语言习题及答案 第二篇_C语言习题及答案

习题一

【习题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】有一函数

(x1) x  y2x-1 (1x10) 3x-11 (x100) 

c语言习题及答案 第三篇_C语言练习题及答案

单项选择题:

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[

本文来源:http://www.gbppp.com/jd/467111/

推荐访问:
推荐内容:

热门文章