整理后的C语言基础题.docx_第1页
整理后的C语言基础题.docx_第2页
整理后的C语言基础题.docx_第3页
整理后的C语言基础题.docx_第4页
整理后的C语言基础题.docx_第5页
已阅读5页,还剩48页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1.二进制语言是属于()面向机器语言面向问题语言面向过程语言面向汇编语言解人们研制了许许多多计算机程序设计语言,其中二进制语言直接来自计算机的指令系统,与具体计算机紧密相关,所以是一种面向机器语言。面向问题语言是为了易于描述和求解某类特定领域的问题而专门设计的一种非过程语言。面向过程语言是一种能方便描述算法过程的计算机程序设计语言。有汇编语言,但没有面向汇编语言。汇编语言也是一种面向机器的语言,与机器语言比较,汇编语言用有助于记忆的符号来代表二进制代码。所以解答是。2.下列语言中不属于面向过程的语言是()高级语言低级语言C语言PASCAL语言解C语言和PASCAL等程序设计语言都是高级语言,它们用于描述复杂加工的处理过程,所以也称它们是面向过程语言。低级语言是指机器语言和汇编语言,低级语言是面向机器的语言,而不是面向问题的语言。所以解答是。3.下列字符中属于键盘符号的是()ntb解键盘符号是指键盘上有标记,并能在显示器上直接以其标记字样显示的字符。有许多键盘上有标记的符号,它们不是用于直接显示的,键入这种字符用于表示特定的意义,如常用的回车符。为了能让C程序标记这种符号,程序采用转义字符的方式书写这种字符。如n、t、b都不是键盘字符,在C语言中,它们都得用转义字符来表达。只有字符才是键盘字符。所以解答是。但在C程序中,反斜杠字符已特别用作转义字符的引导符,它也得用转义字符的表达形式书写,将它写成。4.下列字符列中,不是用来表达转义字符是()0740解转义字符有三种书写形式:反斜杠字符后接上某个规定的字符;反斜杠字符后接上13个八进制数字符;反斜社字符和字符X之后接上1至2个十六进制数字符。后两种分别八进制数和十六进制数直接给出字符的ASCll代码值。而074是八进制整数,不是转义字。所以解答是。5.不是C语言提供的合法关键字是()switchbegincasedefault解因C语言的关键字表中没有begin,它不是C语言的关键字。所以解答是。6.下列字符列中,能作为单个标识符是()?aa2a.3a_3解在C语言中,规定标识符是这样一种字符序列,由英文字母或下线字符开始,后接任1个英文字母、下线字符和数字符组成。所以问题所列的字符列只有a_3是标识符,其余都不是标识符,一个是由字符?开头、一个中间有字符,另一个有字符.。所以解答是。7.在C语言中,下列说法中错误的是()函数定义可以分为两个部分:函数说明部分和函数体主函数可以调用任何非主函数任何非主函数可以调用其它任何非主函数程序可以从任何函数开始执行解每个C函数的定义分两部分,函数说明部分和函数体,所以叙述是正确的叙述。C语言中,函数可以递归调用,主函数可以调用程序中的任何函数,当然可以调用任何非主教的其它函数,所以叙述是一个正确的叙述。同样理由,叙述也是正确的。C语言规,C程序只有一个主函数,并总是从主函数开始执行,不能从非主函数开始执行。所以,说程可以从任何函数开始执行是错误的。所以解答是。1.2填充题 1.汇编语言属于面向_语言,高级语言属于面向_语言。解汇编语言与具体计算机密切有关,是属于面向机器的语言;而高级语言用来描述求解题的算法,所以是面向过程的语言。所以解答是:面向机器和面向过程。 2.用高级语言编写的程序称为_程序,它可以通过_程序翻译一句执一句的方式执行,也可以通过_程序一次翻译产生_程序,然后执行。解用高级语言编写的程序称为源程序,源程序不能在计算机上直接运行,运行源程序有种方式:一种是通过解释程序,对源程序逐句解释执行;另一种是先让编译程序将源程序一翻译产生目标程序(目标程序是计算机可直接执行的机器语言程序,它是一种二进制代码程),然后执行目标程序。 3.转义字符是由_符号开始,后接单个字符或若干字符组成。 4.C语言词类主要分为_、_、_和_等。解语言的基本词汇是指直接由字符序列组成,有确定意义的最基本单位,所以C语言词汇有:字面形式常量、特殊符号(主要是运算符)、保留字和标识符等四类。而表达式、函数调用等是更高级的语言成分,如表达式中还可分运算分量和运算符等;函数调用也是一种表达式,它有函数名标识符、圆括号和实际参数表等。利用基本词汇,按照给定的C语言的句法规则,就可命名程序对象,描述表达式计算、构造语句、函数,直至整个程序。 5.C语言的语句主要分为_语句、_语句、_语句_语句、_语句和_语句等。解C语言有多种不同功能的语句,有用于定义数据的,有用于各种存储和计算的,有用于程序流程控制的,有多种分类方法。C语言的语句主要有:数据定义语句、表达式语句、流程控制语句、复合语句、空语句和其它语句。程序中经常使用的赋值表达式语句和函数调用表达式语句都是典型的表达式语句。 6.C程序是由函数构成的。其中有并且只能有_个主函数。C语言程序的执行总是由_函数开始,并且在_函数中结束(如别的函数未调用终止程序执行的库函数)解C程序是由若干函数构成的。其中有并且只能有1个主函数(用main命名)。C程序的执行总是由主函数开始执行,通常在主函数中结束(如没有在别的函数中调用终止程序执行的库函数的话)。第二章基本数据类型和表达式2.1单项选择题1.下列字符列中,可以作为“字符串常量”的是()ABC“ABC“abca解C程序中,一个字符率常量是表示一个字符序列,书写时,用双引号字符前后括住这个字符序列。所以只有“ABC”是一个正确的字符率常量,其余都不是。其中,ABC可作为标识符,字符列abc不能出现在C程序中,a是一个字符常量。所以解答是。2.在以字节存储字符的系统中,n在内存占用的字节数是()1234解一般来说,一个字符在内存中只占1个字节,n是转义字符,其意义是换行符,它作为一个字符存储,在内存也只占1个字节。所以解答是。3.字符串“xyz”在内存占用的字节数是()3468解字符串中的每个字符占1个字节,但C程序在存储字符串时,要在最后一个有效字符后面接上1个字符串结束的标记符0。这样,存储字符串常量“xyz”需要4个字节。所以解答是。4.在以下字符列中,合法的长整型常数是()0L49627100.0548387432.1869el0解为表示不同范围的整数,整型数据分短整型、基本型和长整型,并对三种整型内部表示的最高位的不同理解,又分别分成无符号和带符号两种。若要明确指明一个整数是长整型的,必须在整数之后接上字符L。所以0L是一个长整型的整型常量,而4962710是基本整型数据,而对于用2个字节表示一个基本整型数据的系统来说,该整数将因超出范围而是一个错误的整数;0.054839743和2.1869el0都是double型的实数。所以解答是。5.一个char型数据,它的值在内存中存放的是()ASCll代码值BCD代码值内码值十进制代码值解计算机存储字符,通常是存储字符的某种代码值。有许多种字符编码的方法,最流行的是ASCII代码。在C语言中,Char型数据也用ASCII代码表示。所以解答是。6.设变量m,n,a,b,c,d的初值均为0,执行(mab)|(ncd)后,m,n的值是()0,00,1l,01,1解计算(mab)|(n=c=d)的过程是先计算逻辑或的左运算分量(m=a=b)的值,由于赋位运算符的优先级比关系运算符=的优先级低,又先计算a=b.因a,b均为0后,所以比较结果值为1.将1赋给变量m,使变量m的值变为1.同时这个赋值运算的结果也是1,这样逻辑运算的左运算分量的值为1.由于逻辑或运算的左运算分量值为1,按照C语言对逻辑或运算优化计算的规定,不再计算逻辑或的右运算分量,而直接得到逻辑或运算的结果为1.由于逻辑或的右运算分量不曾计算过,所以变量n的值也不为变化。这样,上述表达式计算后,变量m的情为1,变量n的值为0.所以解答是。7.设a为5,执行下列计算后,b的值不为2的是()ba2b6-(-a)ba2ba3?3:2解因两个整型数据相除,结果是整数,当a的值为5时,计算表达式b=a2后,使b的值为2.计算表达式b6-(-a)是先计算子表达式(-a)的,先让a的值减1变成4,并以减1后的a为子表达式的结果,所以子表达式的结果为4,最后使b的值为2.在计算表达式b=a%2时,求余运算a2的结果为1,最后使变量b的值为1.计算表达式ba3?3:2时,先计算条件表达式a3?3:2,以2为结果,最后也使变量b的值为人所以解答是。8.执行语句“x(a3,ba-);”后,X,a,b的值依次为()3,3,22,3,23,2,32,3,3解计算表达式x(a=3,b=a-)时,先计算赋值号右端圆括号内的逗号表达式。逗号表达式要求各子表达式顺序计算,并以最后予表达式的值为整个逗号表达式的结果。所以该表达式计算时,先让变量a的值为3,a-的值是a当时的值,以该值为结果赋给变量b,并以该值为逗号表达式的值赋给变量x,然后a的值被减少1.所以计算该表达式后,使变量x,a,b的值依次为3,2,3.所以解答是。9.设整型变量m,n,a,b,c,d均为1,执行“(mab)(nab)”后m,n的值是()0,00,l1,01,l解表达式(mab)(nab)是一个逻辑表达式,它的计算过程是先计算逻辑与的左分量(mab,其中又是先计算ab.因ab不成立,结果为0,将0赋给变量m,最后逻辑与的左分量结果为0.由于逻辑运算采用特别的优化计算规则,当逻辑与的左分量结果为0时,不再计算逻辑与的右分量,而直接以0为逻辑与的结果。所以,上述表达式计算使m的值变为0,而n的值没有变,依旧为l.所以解答是。10,设有代码“inta3;”,则执行了语句“a+=a-=a*a;”后,变量a的值是()309-12解由于赋值运算符的结合性自右至左,语句“a+=a-=a*a;”的执行是先计算a*a,得到值9,再计算a-a*a,使a的值为-6,接着计算a+a,使a的值为-12.所以解答是。11.在以下一组运算符中,优先级最高的运算符是()%解常规运算符的优先级自高到低的排列顺序是算术运算符、移位运算符、关系运算符。按位运算符、逻辑运算符、条件运算符、赋值运算符、逗号运算符。所以问题所给的四个运算符按优先级自高到低的排列顺序是,。所以解答是。12.设整型变量i的值为3,则计算表达式i-i后表达式的值为()0l2表达式出错解有些运算符只有一个字符,也有许多运算符由两个字符组成。特别是有些字符既可是单个字符的运算符,又能组成双字符的运算符。编译系统在识别源程序时,通常是尽量多地读八字符,能组成多字符单词的先尽量组成多字符单词。所以表达式i-i,被编译器理解为(i-)-i.另外,当表达式中某变量有后缀自增和自减运算时,先按变量的原值计算表达式,然后再对变量进行自增和自减运算。同样地,当表达式中某变量有前缀自增和自减运算时,先对变量进行自增和自减运算,然后再按变量的新值计算表达式。按这个约定,求表达式(i-)-i是计算i-i的值为0,然后再对i作自减运算。这样,表达式(i-)-i的值为0.所以解答是。13. 设整型变量a、b、c均为2,表达式a+b+c+的结果是()14. 698表达式出错解与上一小题解答的理由相同,表达式a+b+c+被系统理解成:(a+)+(b+)+c+)。表达式“变量+”的值是变量的原来值,所以在变量a、b.c均为2的前题下,执行上述表达式,得到结果为6.所以解答是。14.若已定义x和y为double类型,则表达式:xl,yx32结果是()l22.02.5解由于变量x和y都是double类型,表达式xl,yx32是先计算x1,由于1是整型的,x是double类型的,该计算先将整数1转换成double类型的1.0,并将1.0赋给变量x.计算yx32是先求32的值,因是两整数相除,结果是整型值1,然后在计算x1时,也先将1转换成1.0,然后求得xl的值为2.0,最后将该值赋给变量y,并得到整个表达式的值为2.0.所以解答是。15.设a=1,b=2,c3,d4则表达式ab?a:cd?a:d的结果为()4321解条件运算符的优先级比关系运算符的优先级低,并且它的结合性是自右向左的,所以表达式ab?a:cd?a:d可用圆括号等价地写成(ab?a:(cD)?A:D)。因AB成立,计算结果为A的值1.所以解答是。16.设a为整型变量,下列C表达式中,不能表达数学关系式:10a15的是()10a15a11|a12|a13|a14a10a15!(a10)!(a=15)解数学关系式10a15表示。只能是11,12,13,14四个值之l.用C表达式表示这个条件,可写成a10a15,或!(a10)&!(a=15),或a11|a12|a=13|a14等。若写成10a15,该算式的计算顺序是先求出10a的结果0或1,然后以这个结果与15比较,是否小于15,显然这与数学式子的意义是不一致的。所以解答是。17. 下列表达式中,正确的C赋值表达式是()18. a7bca7a7ba7a(7b,b,a7)a7b,ca7解赋值运算符是运算符之一,赋值运算也可以出现在一般表达式中。赋值运算时,出现在赋值运算符左边的表达式应该是引用一个存储对象,例如变量。不可以是一个数值计算表达式。如表达式a7bca7因算术运算符比赋值运算符的优先级高,要把a7的结果赋给7bc,这是错误的。同样理由,表达式a7ba7也是错误的。而表达式a(7b,b,a7)就是正确的赋值表达式,它是先计算赋值号左边的括号内的表达式,括号表达式内是一个逗号表达式,远号表达式要求顺序逐一计算各子表达式,并以最后一个子表达式的值作为远号表达式的结果,最后将该结果赋给变量a.而表达式a7b,ca7则不是一个赋值表达式,而是一个逗号表达式,它由两个赋值子表达式组成。所以解答是。18.若有以下定义:chara;intb;floatc;doubled;则表达式a*b+d-c值的类型为()floatintchardouble解基本类型的数据可以混合运算,但运算时,对要求运算分量类型相同的运算来说,如运算分量的类型不是全相同,则会有自动类型转换发生。类型自动转换规则规定类型低(简单)的向类型高(复杂)的转换。各类型由高到低的排列顺序是:longdouble、float、unsignedlong、long、unsignedint、int这样,若有定义:chara;intb;floatc;doubled;则表达式a*b+d-c的值的类型是double的。首先计算a*b,得到int类型的值,接着计算a*b+d,得到double类型的值,最后计算a*b+d-c,得到double类型的值。所以解答是。19.表达式“9!=7”的值是()true非0值01解关系运算的结果只有0和1,若关系成立,则结果为1;若关系不成立,则结果为0.因关系式9!7成立,所以表达式的结果为1.虽然1也是非0值,在供选择的答案中有1,所以最确切的解答是。21.设字符型变量a3,b6,计算表达式C(ab)2后C的二进制值是()00011100000001110000000100010100解a的值为3,写成8位二进制数形式是00000011,b的值为6,写成8位二进制数形式是00000110.表达式c(ab)2,先计算a与b的按位加,得到结果00000101,将这结果向左移2位,得到二进位的位串信息是00010100.所以解答是。22.设a,b和c都是int型变量,且a3,b4,c5,则下面的表达式中值为0的是()ababa|b+cb-c!(aB)!|1)解对于表达式ab,两个非O运算分量的逻辑与结果为1.对于表达式ab,由于关系式成立,结果也为此又由于变量a为非0,表达式a|b+cb-c的结果也为1.对于表达式!(ab)!c|1),先是计算(ab)得到结果1;计算!C得到结果为0;再计算它们的逻辑与,结果为0.继续与1求逻辑或,得到结果为1.最后,对1求逻辑非,得到结果为0.所以解答是。23.设ch是char型变量,其值为A,则下面表达式的值是()ch(chAchZ)?(ch32):chAaZz解由于字符型变量ch的值为A,计算表达式chhAchZ)?(ch32):ch,先计算其中条件表达式,由于条件(chAhZ)成立,该条件表达式以ch3297为结果,将该值赋给变量ch,以字符表达这个值为a。所以解答是。2.2填充题1.在内存中,存储字符串“X”要占用_个字节,存储字符X要占用_个字节。解计算机存储一个字符用1个字节,存储字符串时,每个字符要占用1个字节,另在字符串的有效字符之后存储1个字符串的结束标记符。所以存储字符率“X要占用2个字节,存储字符X只要1个字节。2.在C程序中,判逻辑值时,用_表示逻辑值“真”,又用_表示逻辑值假“。在求逻辑值时,用_表示逻辑表达式值为”真“,又用_表示逻辑表达式值为”假“。解在C程序中,判逻辑值时,用非0值表示真;而判逻辑值时,用值0表示假。但逻辑表达式计算结果,逻辑表达式值为真是用1表示的,而逻辑表达式的值为假,则用0表示。3.定义符号常量的一般形式是_.解定义符号常量用预处理命令的宏定义,其定义的一般形式是:define符号常量名常量4.在函数内,说明变量时,若省略存储类型符,系统默认其为_存储类别,该存储类别的类型符为_.解在函数内,说明变量时,若省略存储类型符,系统就默认其为自动存储类别,该存储类别用auto标识。5.无符号基本整型的数据类型符为,双精度实型数据类型符为,字符型数据类型符为。解无符号的基本整型的类型符为unsignedint,或简写成unsigned.双精度实型数据类型符为double,字符型数据类型符为char.6.定义指定数据类型的变量时,较完整的一般形式是。解要指定变量的存储类型,定义指定类型的变量,其一般形式是:存储类型符数据类型符变量名1,变量名2,;7.设有下列运算符:、,其中优先级最高的是_,优先级最低的是_.解对运算符、,按它们的优先级自高到低的顺序排列为:、所以,优先级最高的是+,优先级最低的是。8.设二进制数A是0A101111,若想通过异或运算AB使A的高4位取反,低4位不变,则二进制数B应_.解按位加运算的一个重要应用是让某个整型变量的二进位位串信息的某些位信息反向,0变成1,而1变成0.这只要设计这样一个位串信息,让要变反的位为1,不要改变的位为0,用这个位串信息与整型变量按位加就能得到希望的结果。要使字节的高4位取反,低4位不变,则需要位串信息是11110000,写成八进制数是0360,写成十六进制数为0xF0.9.设a3,b=2,cl,则cb的值为_.,abc的值为_.解因a的值为3,b的值是2,条件ab为真,其值为1.表达式abc的求值顺序是计算ab,结果为1,接着计算1c,因c的值为1,条件1c为假,结果为0.10.已知a10,b20,则表达式!ab的值为_.解计算表达式!ab,先计算!a,因a的值为10,!a的值为0.关系表达式020为真,所以表达式!ab的值为1.11.设x和y均为int型变量,且xl,y2,则表达式1.0xy的值为_.解计算表达式1.0xy,先求xy,因x和y是整型变量,其中的除运算是整除,12的结果为0.接着计算1.00,计算时,先将右分量转换成0.0,最后得到结果1.0.12.设整型变量x、y、z均为5:执“x-y-x”后,x_,执行“xyz”后,x=_.执行“x(yz)?x2:x2,3,2后,x_.解在变量x、y、z的值均为5的情况下,计算各表达式。由于表达式x-yz等价于表达式xx(yz),所以计算后x的值为5.表达式x%=yz等价于表达式xx%(yz),所以计算后x的值也为5.表达式x(yz)?x2:x2,3,2的计算过程用圆括号描述其计算顺序是:(x=(yz)?x2:x2),3),2即这是一个逗号运算表达式,由一个赋值表达式和两个数值构成,逗号表达式要求顺序求各子表达式的值。表达式x(yz)?x2:x2的计算是先求赋值号右边的条件表达式,因条件(yz)为假,求出x2的值为3,将该值赋给变量x,使x的值为3.13.能表述“20x30或x-100”的C语言表达式是_.解首先表述20x30的C表达式可写成20xx30.所以表述“20x30或x-100”的C表达式为20xx30|x-100.14,请写出数学式x/y*z的C语言表达式_.解数学式子表述的是x除以y乘z的积,写成C表达式可以写为x(y*z),或可等价地写成xyz.15.C语言中运算结果可以当成逻辑值使用的表达式有:_表达式、_.表达式、_表达式、_表达式、_表达式、_表达式。解在C语言中,逻辑判断以非0值为真,以0值为假。所以,几乎所有的表达式的运算结果都可以当成逻辑值使用,如算术表达式、关系表达式、逻辑表达式、赋值表达式、逗号表达式、条件表达式等。第三章C程序结构3.1单项选择题1.设a3,b4执行“printf(“d,d,(a,b),(b,a);”的输出是()3,44,33,34,4解在调用格式输出函数的语句中,其中每个格式符对应一个输出项,格式符d要求输出项内容以十进制整数形式输出。第一个输出项(a,b)是一个逗号表达式,该表达式的值是b的值,输出4.接着输出字符逗号。第二个输出项(b,a)的值是a的值,输出3.所以语句执行将输出4,3.正解的选择是。2.使用“scanf(”x=%f,y%f“,x,&y)”,要使x,y均为1.25,正确的输入是()1.25,1.251.251.25x1.25,y1.25X1.25y1.25解格式输入函数的格式字符串中的字符可以分成三类:空格类字符、其它普通字符和格式转换说明。其中空格类字符用来跳过一个空格类字符序列,直至下一个非空格类字符。普通字符要求输入字符与其完全相同。格式转换说明对输入字符列按格式转换说明进行转换,得到内部值存储到对应输入项所指定的存储位置中。函数调用scanf(“x%f,y=%f,x,&y)以普通字符x=开头,输入时也要先输入x。接着是一个浮点数输入格式,所有能构成一个浮点数1.25的字符序列都能满足要求。接着是普通字符列”,y“,在输入的浮点数之后也要有字符列”,y“。最后又是浮点数输入格式,同样所有能构成一个浮点数1.25的字符序列都能满足要求。问题给出的供选择答案中只有x=1.25,y1.25是能满足上述要求的。所以正确选择是。3.设有inti010,j=10;则执行“printf(”%d,%dn“,+i,j-);”的输出是()ll,109,10010,910,9解变量i和j的初值分别为八进制数010和十进制数10,函数调用Printf(“%d,%dn”,+i,j)中,+i的值是变量i增1后的值,原来值是八进制数010,等于十进制数8,输出9.j的值是变量j减1之前的值,输出10.格式字符申中的逗号是普通字符照原样输出。所以问题给出的格式输出函数调用将输出9,10.正确的解答是。4.设a,b为字符型变量,执行“scanf(”a%c,b%c“,&a,&b)”后使a为A,b为B,从键盘上的正确输入是()A“BA,BAA,BBa=A,bB解函数调用scanf(“c%c,b%c”,&c,&b)中,普通字符必须按格式字符串要求照原样输入,c格式对紧接的任何字符都输入。所以实现问题的要求,输入字符列应为“aA,bB”。另外要特别指出,在程序中,为表示字符常量,字符前后需加单引号。但用字符格式输入字符时,在要输入字符前后不必另键人单引号。若键人单引号,则这个单引号也将作为字符被输入。正确的解答是。5.设x、y、z、t均为int型变量,则执行以下语句后,t的值为()xyz1;t+x|+y+z;不定值2l0解语句序列“xyzl;t+x|+y&+z;”使变量x的值为1,变量t是赋一个逻辑表达式的值。在C语言中,由逻辑与和逻辑或构成的逻辑表达式有特别的计算规则,顺序计算各逻辑子表达式,并当一旦能得到逻辑表达式的结果时,就立即结束逻辑表达式的计算,不再计算后继逻辑子表达式。本题的逻辑表达式是两个运算分量的逻辑或,而且左运算分量+x的值为非0,立即得到逻辑或运算的结果为1,并将1赋给变量t,所以变量t的值为1.正确解答为。6设x、y、z均为int型变量,则执行以下语句后,x、y,z的值为()x1;y0;z2;yz|+x;2、l、32、0、32、l、32、1、2解语句序列“xl;y0;z2;y+&+z|+x;”先使变量x的值为1,变量y的值为0,变量z的值为2.由逻辑与和逻辑或构成的逻辑表达式的特别计算规则,顺序计算各逻辑子表达式,并当一旦能得到逻辑子表达式的结果时,就立即结束逻辑子表达式的计算,不再计算该逻辑子表达式。计算y+因y的值为0,使y+&+z的结果为0,立即去计算+x,这次计算使变量y的值变成1,而变量z的值本改变。接着计算+x,使x的值变为2.所以经上述语句执行后,x、y、z的值依次为2、1、2.正确解答为。7.假定所有变量均已正确定义,下列程序段运行后x的值是()abc0;x35;if(!a)x-;elseif(b);if(c)x3;elsex=4;344353解以变量a,b,c的值均为0,变量x的值为35,语句:if(!a)x-;elseif(b);if(c)x3;elsex4;由两个if语句组成。首先执行前一个if语句“if(!a)x-;elseif(b);”,因变量a的值为0,条件!a成立,执行x-使x的值变为34.接着执行后继的if语句“if(c)x3;elsex4;”,因变量c的值为0,条件不成立而执行x4,最终使变量x的值为4.正确解答是。注意前一个if语句的else部分的成分语句只有“if(b);”,这是一个单分支if语句,且其成分语句为空语句。9.下列语句中,句法错误的是(不考虑语义)()while(xy)5;dox+while(x10);while(0);do2;while(ab);解while语句的一般形式是:while(表达式)语句这里的表达式可以是任何合理的表达式,语句可以是任何语句,包括空语句,或表达式语句。可能书写的while语句没有任何意义,如供选择的while(xy)5;和while(0);,但这两个语句的句法没有任何错误。do-while语句的一般形式是:do语句while(表达式);其中的成分语句也可以是任何语句,但供选择答案dox+while(x=10);中的代码x+是一个表达式,不是语句,语句必须要以分号结束,所以是错误的。正确解答是。10,循环语句“for(x0,y0;(y!=123)|(x4);x);”的循环执行()无限次不确定次4次3次解for循环语句的初始化部分置变量x和y的初值为0,循环条件是(y!123)|(x4),每次循环后变量X的值增1.由于循环过程中变量y的值未被修改过,循环条件又是一个逻辑或,其左分量(y!123)永远成立,也就是循环条件永远成立。所以该循环语句将循环执行无限次。正确解答是。11.若i、j已定义为int类型,则以下程序段中的内循环体的执行次数是()for(i5;i;i-)for(j0;j4;j+)20242530解问题所给的程序段的外循环是一个阶循环语句,它的初始化部分置变量i的初值为5,循环条件简写成i,即i!0,每次循环后变量i的值减1.所以外循环共控制5次循环。内循环也是一个for循环语句,它的初始化部分置变量j的初值为0,循环条件是j4,每次循环后变量j的值增1.所以内循环共控制4次循环。这样,如内循环的体内未曾对变量i和j有修改,在内、外循环一起控制下,内循环体共被重复执行20次。正确解答是。12.假定a和b为int型变量,则执行以下语句后b的值为()a1;b10;dob-a;a+;while(b-0);9-2-18解在这个程序段中,循环开始前变量a的值为1,b的值为10,每次循环从变量b减去a,并让a增1,并在循环条件判定时,又让b减去1.第一次循环后,变量b的值变成9,变量a的值变为2,循环判断时,因b的值大于0,循环条件不成立,结束循环。但在循环判断时,让b减去了1,所以循环结束时,变量b的值为8.正确的解答是。13.设x和y为int型变量,则执行下面的循环后,y的值为()for(yl,xl;y50;y)if(x10)break;if(x2=1)x5;continue;x-3;2468解for循环语句的初始化部分置变量x和y的初值为1,循环条件是(y50),每次循环后变量y的值增1,控制循环最多执行50次。循环体有三个语句:首先在发现变量x的值大于等于10时,结束循环;接着是当变量x除2的余数为1(即变量x是奇数)时,让变量X值增5,让x变成偶数,并直接进入下一轮循环;如变量x是偶数,则从变量x减去3,让变量x变成奇数。由上述分析知,每两次循环使变量x的值增加2.第一次循环后,变量x的值变成6.第二次循环后,变量x的值变成3.第三次循环后,变量x的位变成8.第四次循环后,变量x的值变成5.第五次循环后,变量x的值变成10.第六次循环时,因变量x的位大于等于10,直接跳出循环,这次循环是非正常结束,对变量y的修正只执行了5次。所以循环结束后,变量y的值增至6.正确的解答是。14.在C语言中,下列说法中正确的是()不能使用“do语句while(条件)”的循环“do语句While(条件)”的循环中必须使用“break”语句退出循环“do语句while(条件)”的循环中,当条件非0时将结束循环“do语句while(条件)”的循环中,当条件为0时将结束循环解do-while语句的一般形式是:do语句while(表达式);其语义是重复执行其成分语句,直至表示条件的表达式值为0时结束。do-while语句是正常使用的一种循环结构之一。do-while语句的循环结束条件由while后的表达式值为0所控制,并不一定要有break语句跳出循环来结束循环。do-while语句在条件值非0时,将继续循环,而不是结束循环。条件值为0时,才结束循环。所以正确的选择是。3.2填充题1.结构化程序设计规定的三种基本结构是_结构,选择结构和_结构。解结构化程序设计的三种基本控制结构是顺序结构、选择结构和循环结构。2.若有定义“inta25,b14,c19;”,以下语句的执行结果是_.if(a+25b-2c+)prinif(“*ad,bd,cdn”,a,b,c);elseprintf(“#ad,bd,cdn”,a,b,c);解问题所给的if语句中,条件a+25b-2c+是先求逻辑与的第一个运算分量,它是一个关系式,关系成立。接着判定第二个逻辑与运算分量,又是一个关系式,由于变量b的值是14,b不小于等于2,运算分量的关系式不成立,导致if语句的条件为假,执行else部分。在求且语句的条件时,计算了2个逻辑与分量,使变量a的值增了1,变量b的值被减了1.所以输出内容是:a=26,b13,c19.3.以下两条if语句可合并成一条if语句为_.if(ab)x1;elsey2;if(ab)printf(“*y=%dn”,y);elseprintf(“#x%dn”,x);解在以上两条if语句中,两个条件刚巧相反。若将前一个if语句的第一个成分语句与第二个if语句的第二个成分语句合并;第一个if语句的第二个成分语句与第二个if语句的第一个成分语句合并,写成一条if语句如下:if(ab)x1;printf(“#x%dd,x);elsey2;printf(“*y%dn”,y);4.设i,j,k均为int型变量,则执行完下面的for语句后,k的值为_.for(i=0,j10;ij;i+,j-)kij;解该for语句以i为0、j为10初始化,循环条件是ij,每次循环后i增1、j减1,循环体是将i与j的和赋给k.这样变量k将保存的是最后一次赋给它的值。一次循环后i为l.j为9,二次循环后i为2.j为8,五次循环后i为5.j为5,继续第六次循环,将i与j的和10存于k后,i为6、j为4,结束循环。所以循环执行后k为10.5.下列程序的功能是输入一个整数,判断是不是素数,若为素数输出1,否则输出0,请为程序填空。main()inti,x,y=1;scanf(“d”,x);for(i=2;i=x/2;i+)if_y=0;break;printf(“dn”,y);解为判数x是否是素数,预置变量y的值为1(x可能是素数),然后用循环,用2至x2的整数i测试对x的整除性,若能被其中的某个整数整除,则x是合数,置y的值为0(不是素数),结束测试循环。若都不能整除,则x为素数。i能否整除x,可用求余运算xi等于0来判定。所以程序中的空框可填xi0.测试X为素数的代码可写成:yl;for(i2;ix2;i+)if(xi0)y0;bleak;3.3程序分析题1.阅读程序,写出运行结果。main()inta10,b4,c3;if(ab)ab;if(ac)ac;printf(“d,d,dn”,a,b,c);解程序中,第一个if语句if(ab)ab,当ab时,让b值置a,该语句确保a的值不比b小。同样第二个IF语句if(ac)ac,当ac时,让C值置A,使A的值不比C小。实际;情况是a本来就比b和c都大,所以a的值没有变,程序输出a、b和c的原来值:10,4,3.2.阅读下列程序,写出程序的输出结果。main()intx=100,a10,b20,ok15,ok20;if(ab)if(b!15)if(!ok1)x1;elseif(ok2)x10;elsex-l;printf(“dn”,x);解程序预置变量x的值为100,a的值为10,b的值为20,ok1为5,ok2为0.程序中给出的if语句可以写成更结构化的形式如下:if(ab)if(b!15)if(!ok1)x1;elseif(ok2)x10;elsexl;由于条件ab成立,并且条件b!=15也成立,而ok1不等于0,执行else后的语句。又因ok2等于0,执行else后的语句赋-1给x.所以程序输出-l.3.阅读下列程序,写出程序的输出结果。main()inty9;for(;y0;y-)if(y3=0)printf(“d”,-y);continue;解循环前,变量y的值为9,其中的循环语句在y大于0情况下循环,每次循环后y的值减1.循环体是当y能被3整除时输出表达式-y,输出的是减1后的y值。这样,第一次循环因y为9,能被3整除,输出8,y也变成8.又经两次循环,y的值变为6,又让y减1变成5,并输出5;又经两次循环,y的值变成3,让y减至变成2,输出2;再经两次循环后,y的值变成0,结束循环。所以程序输出852.3.4程序设计题1.编一个程序,输入华氏温度(F),按下列公式计算并输出对应的摄氏温度(C):C5(F32)9解利用公式:C5(F32)9,输入F氏温度,计算并输出对应的C氏温度,程序要引入两个变量,分别用于存储F氏温度和C氏温度,计算时应采用浮点型,包括公式中的常数也应写成浮点数,不能采用整型和把常数写成整数。因采用整型编写,公式中的除运算变成整除,会得出与实际要求不一致的结果。程序如下:includemain()floatf,c;/*变量定义*/printf(“输入F氏温度”);scanf(“f,f);c5.0*(f32.0)9.0;printf(“对应的C氏温度6

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论