欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    《C语言程序设计》练习题.docx

    • 资源ID:14822246       资源大小:58.39KB        全文页数:84页
    • 资源格式: DOCX        下载积分:1金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要1金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    《C语言程序设计》练习题.docx

    1、C语言程序设计练习题C程序设计练习题一、单项选择题导读:单项选择题要求从给出的四个备选答案中,选出一个最符合题意的答案。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题,应该通过上机实验来检验。(注:选用普通整型数据占用2个字节的c编译器。如 Turbo C 2.0 、Win-TC、Turbo C+ 3.0)【1.1】以下不正确的C语言标识符是_。A) int B) a_1_2 C) ab1exe D) _x【1.2】以下是正确的C语言标识符是_。A) #define B) _123 C) %d D) n【1.3】下列四组字符串中

    2、都可以用作语言程序标识符的一组是 。 A) print B) iam C) Pxq D) str_l _3d one_half My-book Cpp oodbs tart$it line# pow aBc 3pai His.age while【1.4】下面各选项组中,均是C语言关键字的组是 。A) auto,enum,include B) switch,typedef,continueC) signed,union,scanf D) if,struct,type【1.5】下列不属于C语言关键字的是 。 A) default B) register C) enum D) external【1.

    3、6】C语言程序从main()函数开始执行,所以这个函数要写在_。A) 程序文件的开始 B) 程序文件的最后C) 它所调用的函数的前面 D) 程序文件的任何位置【1.7】下列关于C语言的叙述错误的是_A) 大写字母和小写字母的意义相同B) 不同类型的变量可以在一个表达式中C) 在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型 D) 同一个运算符号在不同的场合可以有不同的含义【1.8】在C语言中,错误的int类型(长度为2字节)的常数是 。A) 32768 B) 0 C) 037 D) 0xAF【1.9】执行语句 printf(%x, -1); (int类型长度为2字节)屏幕显示_。A)

    4、 -1 B) 1 C) -ffff D) ffff【1.10】已知 long i=32768; 执行语句printf(%d, i); 屏幕显示_。A) -1 B) -32768 C) 1 D) 32768【1.11】已知 long i=65539; 执行语句printf(%d, i); 屏幕显示_。A) 65539 B) -3 C) 3 D) 程序不能执行【1.12】在语言中,整数-8在内存中的存储形式是 。A) 1111 1111 1111 1000 B) 1000 0000 0000 1000C) 0000 0000 0000 1000 D) 1111 1111 1111 0111【1.1

    5、3】语言中字符型(char)数据在内存中的存储形式是_。 A) 原码 B) 补码 C) 反码 D) ASCII码【1.14】将字符g赋给字符变量c,正确的表达式是 。A) c=147 B) c=147 C) c=147 D) c=0147【1.15】下列转义字符中错误的一个是_。A) 000 B) 0014 C) x111 D) 2【1.16】将空格符赋给字符变量c,正确的赋值语句是_。A) c=0 B) c=NULL C) c=0 D) c=32【1.17】已知:char a=70; 则变量a中 。A) 包含1个字符 B) 包含2个字符 C) 包含3个字符 D) 说明非法【1.18】字符串E

    6、OFn=-61的长度是_。A) 8 B) 9 C) 14 D) 非法字符串【1.19】字符串的长度是_。A) 0 B) 1 C) 2 D) 非法字符串【1.20】已知:char a; int b; float c; double d; 执行语句c=a+b+c+d; 后,变量c的数据类型是 。A) int B) char C) float D) double【1.21】温度华氏和摄氏的关系是:。已知:float C, F; 由华氏求摄氏的正确的赋值表达式是_。A) C=5/9(F-32) B) C=5*(F-32)/9 C) C=5/9*(F-32) D) 三个表达式都正确【1.22】逗号表达式

    7、(a=3*5, a*4), a+15的值是_。A) 15 B) 60 C) 30 D) 不确定【1.23】如果int a=1, b=2, c=3, d=4; 则条件表达式ab?a:cd?c:d的值是_。A) 1 B) 2 C) 3 D) 4【1.24】为求出s=10!的值,则变量s的类型应当为 。A) int B) unsigned C) long D) 以上三种类型均可【1.25】已知int i=10; 表达式20-0=i5&+x10; A) 1 B) 2 C) 3 D) 4【1.27】为判断字符变量c的值不是数字也不是字母时,应采用下述表达式_。A) c=57&c=90&c=122B) !

    8、(c=57&c=90&c=122)C) c=48&c=65&c=97&c=48&c=65&c=97&c=122)【1.28】已知 int a32=3, 2, 1; 则表达式a00/a01/a02的值是_。A) 0.166667 B) 1 C) 0 D) 错误的表达式【1.29】已知 int x=1, y=1, z=1; 表达式x+y+z+的值是_。A) 3 B) 4 C) 5 D) 表达式错误【1.30】已知int x=5, y=5, z=5; 执行语句x%=y+z; 后,x的值是_。A) 0 B) 1 C) 5 D) 6【1.31】使用语句scanf(x=%f, y=%f, &x, &y);

    9、 输入变量x、y的值(代表空格),正确的输入是_。A) 1.25, 2.4 B) 1.252.4 C) x=1.25, y=2.4 D) x=1.25y=2.4【1.32】下列循环语句中有语法错误的是_。A) while(x=y) 5; B) while(0) ; C) do 2; while(x=b); D) do x+ while(x=10); 【1.33】已知int x=(1, 2, 3, 4); 变量x的值是_。A) 1 B) 2 C) 3 D) 4【1.34】表达式sizeof(double)是 。A) 函数调用 B) double型表达式 C) int型表达式 D) 非法表达式【1

    10、.35】已知:int x, y; double z; 则以下语句中错误的函数调用是 。A) scanf (%d, %lx, %le, &x, &y, &z); B) scanf (%2d*%d%lf, &x, &y, &z); C) scanf (%x%*d%o, &x, &y); D) scanf (%x%o%6.2f, &x, &y, &z); 【1.36】与条件表达式(n)?(c+):(c-)中的表达式(n)等价的表达式是_。A) (n=0) B) (n=1) C) (n!=0) D) (n!=1)【1.37】已知int i=1, j=0; 执行下面语句后j的值是_。while(i)sw

    11、itch(i) case 1: i+=1; j+; break; case 2: i+=2; j+; break; case 3: i+=3; j +; break; default: i-; j+; break; A) 1 B) 2 C) 3 D) 死循环【1.38】求取满足式 12+22+32+ +n2 1000的n,正确的语句是_。A) for(i=1, s=0; (s=s+i*i)=1000; n=i+) ; B) for(i=1, s=0; (s=s+i*i)=1000; n=+i) ; C) for(i=1, s=0; (s=s+i*+i)=1000; n=i) ; D) for(

    12、i=1, s=0; (s=s+i*i+)0)&(x4); x+, y- ) ; A) 是无限循环 B) 循环次数不定 C) 循环执行4次 D) 循环执行3次【1.40】已知int i=1; 执行语句while (i+y); A) 1 B) 2 C) 3 D) 程序运行有错误【1.42】已知 char a20=Beijing, shanghai, tianjin, chongqing; 语句printf(%c, a30); 的输出是_。A) B) n C) 不定 D) 数组定义有误【1.43】若用数组名作为函数调用时的实参,则实际上传递给形参的是 。A) 数组首地址 B) 数组的第一个元素值C)

    13、 数组中全部元素的值 D) 数组元素的个数【1.44】对二维数组的正确说明是_。A) int a=1, 2, 3, 4, 5, 6; B) int a2=1, 2, 3, 4, 5, 6; C) int a3=1, 2, 3, 4, 5, 6; D) int a2, 3=1, 2, 3, 4, 5, 6; 【1.45】对字符数组s赋值, 不合法的一个是_。A) char s=Beijing; B) char s20=beijing; C) char s20; s=Beijing; D) char s20=B, e, i, j, i, n, g; 【1.46】对字符数组str赋初值,str不能作

    14、为字符串使用的一个是_。A) char str=shanghai; B) char str=shanghai; C) char str9=s, h, a, n, g, h, a, i; D) char str8= s, h, a, n, g, h, a, i; 【1.47】如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为_。A) 静态变量 B) 动态变量 C) 外部变量 D) 内部变量【1.48】在一个C源程序文件中, 若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是 。A) extern B) register

    15、 C) auto D) static【1.49】在C语言中,函数的数据类型是指_。A) 函数返回值的数据类型 B) 函数形参的数据类型C) 调用该函数时的实参的数据类型 D) 任意指定的数据类型【1.50】已知如下定义的函数:fun1(a) printf(n%d, a); 则该函数的数据类型是_。A) 与参数a的类型相同 B) void型C) 没有返回值 D) 无法确定【1.51】定义一个函数实现交换x和y的值,并将结果正确返回。能够实现此功能的是_。A) swapa(int x, int y) B) swapb(int *x, int *y) int temp; int temp; temp

    16、=x; x=y; y=temp; temp=x; x=y; y=temp; C) swapc(int *x, int *y) D) swapd(int *x, int *y) int temp; int *temp; temp=*x; *x=*y; *y=temp; temp=x; x=y; y=temp; 【1.52】求一个角的正弦函数值的平方。能够实现此功能的函数是_。A) sqofsina(float x) return(sin(x)*sin(x); B) double sqofsinb(float x) return(sin(double)x)*sin(double)x); C) do

    17、uble sqofsinc(x) return(sin(x)*sin(x); D) sqofsind(float x) return(double(sin(x)*sin(x); 【1.53】一个函数内有数据类型说明语句如下:double x, y, z(10); 关于此语句的解释,下面说法正确的是_。A) z是一个数组,它有10个元素。B) z是一个函数,小括号内的10是它的实参的值。C) z是一个变量,小括号内的10是它的初值。D) 语句中有错误。【1.54】已知函数定义如下:float fun1(int x, int y) float z; z=(float)x/y; return(z);

    18、 主调函数中有int a=1, b=0; 可以正确调用此函数的语句是_。A) printf(%f, fun1(a, b); B) printf(%f, fun1(&a, &b); C) printf(%f, fun1(*a, *b); D) 调用时发生错误【1.55】下面函数的功能是_。void a(char s1,char s2) while(*s2+=*s1+) ; A) 字符串比较 B) 字符串复制 C) 字符串连接 D) 字符串反向【1.56】在下列结论中,只有一个是错误的,它是_ 。A) 语言允许函数的递归调用B) 语言中的continue语句,可以通过改变程序的结构而省略C) 有些

    19、递归程序是不能用非递归算法实现的 D) C语言中不允许在函数中再定义函数【1.57】说明语句int (*p)( ); 的含义是 。A) p是一个指向一维数组的指针变量B) p是指针变量,指向一个整型数据C) p是一个指向函数的指针,该函数的返回值是一个整型D) 以上都不对【1.58】设有说明int (*p)4; 其中的标识符p是 。A) 4个指向整型变量的指针变量B) 指向4个整型变量的函数指针C) 一个指向具有4个整型元素的一维数组的指针D) 具有4个指向整型变量的指针元素的一维指针数组【1.59】已知:char s10, *p=s, 则在下列语句中,错误的语句是 。A) p=s+5; B)

    20、 s=p+s; C) s2=p4; D) *p=s0; 【1.60】已知:char s100; int i; 则引用数组元素的错误的形式是 。A) si+10 B) *(s+i) C) *(i+s) D) *(s+)+i)【1.61】已知:char s6, *ps=s; 则正确的赋值语句是 。 A) s=12345; B) *s=12345; C) ps=12345; D) *ps=12345; 【1.62】已知:int a43=1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12; int (*ptr)3=a, *p=a0; 则以下能够正确表示数组元素a12的表达式是

    21、。A) *(*(a+1)+2) B) *(*(p+5) C) (*ptr+1)+2 D) *(ptr+1)2)【1.63】已知:int a =1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, *p=a; 则值为3的表达式是 。A) p+=2, *(p+) B) p+=2, *+p C) p+=2, (*p)+ D) p+=2, +*p【1.64】已知:int a=1, 2, 3, 4, y, *p=a; 则执行语句y = (*+p)-; 之后, 数组a各元素的值变为_。A) 0, 1, 3, 4 B) 1, 1, 3, 4 C) 1, 2, 2, 4 D) 1, 2

    22、, 3, 3变量y的值是_。A) 1 B) 2 C) 3 D) 4 【1.65】已知:int a =1, 3, 5, 7, y , *p= a; 为使变量y的值为3,下列语句正确的是_。A) y=+*p+; B) y=+(*p+); C) y=(+*p)+; D) y=(*+p)+; 【1.66】已知:int x = 1, 3, 5, 7, 9, 11 , *ptr=x; 则能够正确引用数组元素的语句是 。A) x B) *(ptr-) C) x6 D) *(-ptr)【1.67】函数的功能是交换变量x和y中的值,且通过正确调用返回交换的结果。能正确执行此功能的函数是 。A) void fun

    23、a (int *x, int *y) B) void funb (int x, int y) int *p; int t; p=x; *x=*y; *y=*p; t=x; x=y; y=t; C) void func (int *x, int *y) D) void func (int *x, int *y) *x=*y; *y=*x; *x=*x+*y; *y=*x-*y; *x=*x-*y; 【1.68】有定义如下:struct sk int a; float b; data , *p; 如果 p=&data; 则对于结构变量data的成员a的正确引用是_。A)(*).data.a B)

    24、(*p).a C) p-data.a D) p.data.a【1.69】已知:struct st int n; struct st *next; ; static struct st a3=1, &a1, 3, &a2, 5, &a0, *p; 如果下述语句的显示是2,则对p的赋值是_。printf(%d, +(p-next-n); A) p=&a0; B) p=&a1; C) p=&a2; D) p=&a3; 【1.70】已知:struct person char name10; int age; class10=LiMing, 29, ZhangHong, 21, WangFang, 22

    25、; 下述表达式中,值为72的一个是_。A) class0-age + class1-age+ class2-ageB) class1.name5 C) person1.name5D) clase-name5【1.71】已知:struct int i; char c; float a; test; 则sizeof(test)的值是 。A) 4 B) 5 C) 6 D) 7【1.72】已知:union int i; char c; float a; test; 则sizeof(test)的值是 。A) 4 B) 5 C) 6 D) 7【1.73】已知:union u_type int i; cha

    26、r ch; float a; temp; 现在执行temp.i=266; printf(%d, temp.ch)的结果是 。A) 266 B) 256 C) 10 D) 1【1.74】若有以下程序段:struct dent int n; int *m; ; int a=1, b=2, c=3; struct dent s3 = 101, &a, 102, &b, 103, &c ; struct dent *p=s; 则以下表达式中值为2的是 。A) (p+)-m B) *(p+)-m C) (*p).m D) *(+p)-m【1.75】若有以下说明语句,则对结构变量pup中sex域的正确引用

    27、是 。struct pupil char name20; int sex; pup, *p; p=&pup; A) p.pup.sex B) p-pup.sex C) (*p).pup.sex D) (*p).sex【1.76】以下对结构变量stul中成员age的非法引用是 。struct student int age; int num; stu1, *p; p=&stu1; A) stu1.age B) student.age C) p-age D) (*p).age【1.77】若有以下定义和语句:union data int i; char c; float f; a; int n; 则以下语句正确的是 。A) a=5;


    注意事项

    本文(《C语言程序设计》练习题.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开