[IT认证]C语言基本题解答.doc_第1页
[IT认证]C语言基本题解答.doc_第2页
[IT认证]C语言基本题解答.doc_第3页
[IT认证]C语言基本题解答.doc_第4页
[IT认证]C语言基本题解答.doc_第5页
已阅读5页,还剩29页未读 继续免费阅读

VIP免费下载

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

文档简介

C语言基本概念题解答选编一、单项选择题1. 以下字符列中,能作为C程序自定义标识符的是 num(10) file_bak break class+2【解】C语言规定,C程序的标识符的命名规则是要由英文字母或下线字符开头,由英文字母、下线字符和数字符构成的字符序列,并且不可以与C语言规定的保留字相同。在供选择的答案中,选择含有括号字符,不是标识符,它好象是函数调用表达式;选择符合C语言关于标识符的构成规则,所以它可以作为标识符;选择是C语言的保留字,它不可以再被程序设定为标识符;选择是一个加法运算算术表达式,也不可以作为程序的标识符。所以解答是。2下列字符列中,不是用来表达转义字符是 074 0【解】转义字符有三种书写形式:反斜杠字符后接上某个规定的字符;反斜杠字符后接上1至3个八进制数字符;反斜杠字符和字符x之后接上1至2个十六进制数字符。后两种分别以八进制数和十六进制数直接给出字符的ASCII代码值。而074是八进制整数,不是转义字符。所以解答是。3下列字符列中,可以作为“字符串常量”的是 ABC ABC abc a【解】C程序中,一个字符串常量是表示一个字符序列,书写时,用双引号字符前后括住这个字符序列。所以只有ABC是一个正确的字符串常量,其余都不是。其中,ABC可作为标识符,字符列abc不能出现在C程序中,a是一个字符常量。所以解答是。4在用一个字节存储一个字符的系统中,n在内存占用的字节数是 1 2 3 4【解】一般来说,一个字符在内存中只占1个字节,n是转义字符,其意义是换行符,它作为一个字符存储,在内存也只占1个字节。所以解答是。5字符串 xyz在内存占用的字节数是 3 4 6 8【解】字符串中的每个字符占1个字节,但C程序在存储字符串时,要在最后一个有效字符后面接上1个字符串结束的标记符0。这样,存储字符串常量xyz需要4个字节。所以解答是。6设变量m,n,a,b,c,d均为0,执行(m = a=b)|(n=c=d)后,m,n的值是 0,0 0,1 1,0 1,1【解】计算(m = a=b)|(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的是 b = a/2 b = 6-(-a) b = a%2 b = a 3 ? 3: 2【解】因两个整型数据相除,结果是整数,当a的值为5时,计算表达式b = a/2后,使b的值为2。计算表达式b = 6 - (-a)是先计算子表达式(-a),先让a的值减1变成4,并以减1后的a为子表达式的结果,所以子表达式的结果为4,最后使b的值为2。在计算表达式b = a % 2时,求余运算a % 2的结果为1,最后使变量b的值为1。计算表达式b = a 3 ? 3 : 2时,先计算条件表达式a 3 ? 3 : 2,以2为结果,最后也使变量b的值为2。所以解答是。8执行语句“x = (a = 3, b = a-);”后,x,a,b的值依次为 3,3,2 2, 3,2 3,2,3 2,3,3【解】计算表达式x = (a = 3, b = a-)时,先计算赋值号右端圆括号内的逗号表达式。逗号表达式要求各子表达式顺序计算,并以最后子表达式的值为整个逗号表达式的结果。所以该表达式计算时,先让变量a的值为3,a-的值是a当时的值,以该值为结果赋给变量b,并以该值为逗号表达式的值赋给变量x,然后a的值被减少1。所以计算该表达式后,使变量x,a,b的值依次为3,2,3。所以解答是。9设有语句“int a=3;”,则执行了语句“a + = a - = a*a;”后,变量a的值是 3 0 9 -12【解】由于赋值运算符的结合性自右至左,语句“a + = a - = a*a;”的执行是先计算a*a,得到值9,再计算a - = a*a,使a 的值为-6,接着计算a += a,使a 的值为-12。所以解答是。10在以下一组运算符中,优先级最高的运算符是 = = % &【解】常规运算符的优先级自高到低的排列顺序是算术运算符、移位运算符、关系运算符、按位运算符、逻辑运算符、条件运算符、赋值运算符、逗号运算符。所以问题所给的四个运算符按优先级自高到低的排列顺序是%,=,&,=。所以解答是。11设整型变量i的值为3,则计算表达式i-i后表达式的值为 0 1 2 表达式出错【解】有些运算符只有一个字符,也有许多运算符由两个字符组成。特别是有些字符既可是单个字符的运算符,又能组成双字符的运算符。编译系统在识别源程序时,通常是尽量多地读入字符,能组成多字符单词的先尽量组成多字符单词。所以表达式i-i,被编译器理解为(i-)-i。另外,当表达式中某变量有后缀自增和自减运算时,先按变量的原值计算表达式,然后再对变量进行自增和自减运算。同样地,当表达式中某变量有前缀自增和自减运算时,先对变量进行自增和自减运算,然后再按变量的新值计算表达式。按这个约定,求表达式(i-)-i是计算i-i的值为0,然后再对i作自减运算。这样,表达式(i-)-i的值为0。所以解答是。12若已定义x和y为double类型,则表达式:x=1, y = x+3/2的结果是 1 2 2.0 2.5【解】由于变量x和y都是double类型,表达式x=1, y = x+3/2是先计算x=1,由于1是整型的,x是double类型的,该计算先将整数1转换成double类型的1.0,并将1.0赋给变量x。计算y = x+3/2是先求3/2的值,因是两整数相除,结果是整型值1,然后在计算x+1时,也先将1转换成1.0,然后求得x+1的值为2.0,最后将该值赋给变量y,并得到整个表达式的值为2.0,简写成2.0。所以解答是。13设a=1,b=2,c=3,d=4,则表达式a b ? a : c d ? a : d的结果为 4 3 2 1【解】条件运算符的优先级比关系运算符的优先级低,并且它的结合性是自右向左的,所以表达式a b ? a : c d ? a : d可用圆括号等价地写成(a b) ? a : (c d) ? a : d)。因ab成立,计算结果为a的值1。所以解答是。14设a为整型变量,下列C表达式中,不能表达数学关系式:10a15的是 10a10&a15 !(a=15)【解】数学关系式10a10& a 15,或!(a=15),或a = 11 | a = 12 | a = 13 | a = 14等。若写成10a15,该算式的计算顺序是先求出10a的结果0或1,然后以这个结果与15比较,是否小于15,显然这与数学式子的意义是不一致的。所以解答是。15若有以下定义:char a; int b; float c; double d;则表达式a*b+d-c值的类型为 float int char double【解】基本类型的数据可以混合运算,但运算时,对要求运算分量类型相同的运算来说,如运算分量的类型不是全相同,则会有自动类型转换发生。类型自动转换规则规定类型低(简单)的向类型高(复杂)的转换。各类型由高到低的排列顺序是: long double 、double、float、unsigned long、long、unsigned int、int。这样,若有定义:char a; int b; float c; double d;则表达式a*b+d-c的值的类型是double的。首先计算a*b,得到int类型的值,接着计算a*b+d,得到double类型的值,最后计算a*b+d-c,得到double类型的值。所以解答是。 16设a,b和c都是int型变量,且a=3,b=4,c=5,则下面的表达式中值为0的是 a&b a=b a|b+c&b-c !(ab)& !c | 1)【解】对于表达式a&b,两个非0运算分量的逻辑与结果为1。对于表达式a=b,由于关系式成立,结果也为1。又由于变量a为非0,表达式a|b+c&b-c的结果也为1。对于表达式!(ab)&!c|1),先是计算(a0) y = 1; else y = 0;-1 (x0) 1 (x 0) 0 (x0) -1 (x0) 0 (x 0) 1 (x 0) 0 (x 0)【解】程序段首先置变量y的值为-1,接着按变量x值的不同情况重置变量y的值。重置的首要条件是x!=0,若变量x的值为0,则不再重置变量y的值,所以在x值为0情况下,y的值是-1。在变量x的值不等于0的条下,若x的值大于0,重置变量y的值为1;若变量x的值小于0,重置变量y的值为0。所以程序段实现当变量x的值为0时,变量y的值为-1;当变量x的值大于0时,置变量y的值为1;当变量x的值小于0时,置变量y的值为0。正确解答为。23设int a = 8, b = 7, c = 6, x = 1;执行语句 if (a 6) if (b 7) if (c 8) x = 2; else x = 3;后x的值是 0 1 2 3【解】将上述语句写成易读的结构化形式: if (a 6) if(b 7) if (c 8) x = 2; else x = 3;该语句的执行过程是,首先判定(a 6),因a 的值是8,条件成立;接着判定(b 7),因b的值是7,条件不成立。在上述语句中,没有对应if(b 7)的else,上述语句就因(b 7)的条件不成立而不执行任何有意义的动作,结束该语句的执行。这样,变量a、b、c和x的值都不会因执行上述语句而改变,所以变量x 的值依旧保持1。所以解答是。24执行下列程序段 x = 9; while (x 7) printf(“*”); x-; 后输出的结果是 * * * *【解】上述代码以x的初值为9,在x7成立的情况下循环,每次循环输出一个*字符,并让x的值减1。共执行2次循环,也就共输出了2个*字符。所以解答为。25循环语句“for(x=0, y=0; (y!=123) | (x 4); x+);”的循环执行 无限次 不确定次 4次 3次【解】for循环语句的初始化部分置变量x和y的初值为0,循环条件是(y!=123) | (x 4),每次循环后变量x的值增1。由于循环过程中变量y的值未被修改过,循环条件又是一个逻辑或,其左分量(y!=123)永远成立,也就是循环条件永远成立。所以该循环语句将循环执行无限次。正确解答是。26设x和y为int型变量,则执行下面的循环后,y的值为for(y=1, x=1; y = 10) break; if(x%2 = 1) x += 5; continue; x -= 3; 2 4 6 8【解】for循环语句的初始化部分置变量x和y的初值为1,循环条件是(y x2 ? (x = 3) : (x = 4); return x + x1; main() printf(“%dn”, fun(7, 8); 后输出结果是 9 10 11 12【解】上述程序中,主函数以实际参数7和8调用函数fun,并输出函数的返回值。函数fun被调用时,形式参数x1的初值是7,x2的初值是8。函数执行表达式语句x1 x2 ? (x = 3) : (x = 4)这是一个条件表达式,因条件x1 x2不成立,条件表达式求(x = 4),该表达式的求值使函数的局部变量x的值为4。最后,函数返回x + x1的值11。所以解答为。39函数调用语句“f(e1, e2), (e3, e4, e5);”中参数的个数是。 1 2 4 5 【解】上述函数调用中,(e1, e2)和(e3, e4, e5)是两个带括号的表达式,所以函数调用只提供两个实参,其中第一个实参先计算e1的值,然后计算e2,并以e2的值为实参。第二个实参顺序计算e3,e4,e5,并以e5的值为实参。所以解答是。40以下程序中的for循环执行的次数是 #include #define N 2 #define M N+1 #define NUM (M+1)*M/2 main() int i, n = 0; for(i = 1; i =NUM;i+) n+; printf(“%d”, n); printf(“n”); 5 6 8 9 【解】代码NUM被替换成(2+1+1)* 2+1/2,所以其值是8。所以程序中的for循环执行的次数是8次。正确解答是。二、填充题1用高级语言编写的程序称为程序,它可以通过程序翻译一句执行一句的方式执行,也可以通过程序一次翻译产生程序,然后执行。【解】用高级语言编写的程序称为源程序,源程序不能在计算机上直接运行,运行源程序有两种方式:一种是通过解释程序,对源程序逐句解释执行;另一种是先让编译程序将源程序一次翻译产生目标程序(目标程序是计算机可直接执行的机器语言程序,它是一种二进制代码程序),然后执行目标程序。2C程序是由函数构成的。其中有并且只能有个主函数。C语言程序的执行总是由函数开始,并且在函数中结束(如别的函数未调用终止程序执行的库函数)。【解】C程序是由若干函数构成的。其中有并且只能有1个主函数(用main命名)。C程序的执行总是由主函数开始执行,通常在主函数中结束(如没有在别的函数中调用终止程序执行的库函数的话)。3在C程序中,判逻辑值时,用表示逻辑值“真”, 又用表示逻辑值“假”。 在求逻辑值时,用表示逻辑表达式值为“真”, 又用表示逻辑表达式值为“假”。【解】在C程序中,判逻辑值时,用非0表示真;而判逻辑值时,用数0表示假。逻辑表达式计算时,逻辑表达式值为真是用1表示的,若逻辑表达式的值为假,则用0表示。4无符号基本整型的数据类型符为,双精度实型数据类型符为,字符型数据类型符为。【解】无符号的基本整型的类型符为unsigned int,或简写成unsigned。双精度实型数据类型符为double,字符型数据类型符为char。5设有下列运算符:、+、+、&、=,其中优先级最高的是,优先级最低的是。【解】对运算符、+、+、&、=,按它们的优先级自高到低的顺序排列为:+、+、z)?x+2:x-2,3,2”后,x = 。【解】在变量x、y、z的值均为5的情况下,计算各表达式。由于表达式x-=y-z等价于表达式x = x (y-z),所以计算后x的值为5。表达式x%=y+z等价于表达式x = x % (y+z),所以计算后x的值也为5。表达式x =(yz)? x+2 : x-2,3,2的计算过程用圆括号描述其计算顺序是: (x =(yz)?x+2:x-2),3),2即这是一个逗号运算表达式,由一个赋值表达式和两个数值构成,逗号表达式要求顺序求各子表达式的值。表达式x =(yz)?x+2:x-2的计算是先求赋值号右边的条件表达式,因条件(yz)为假,求出x-2的值为3,将该值赋给变量x,使x的值为3。7能表述“20x30或x-100”的C语言表达式是。【解】首先表述20x30的C表达式可写成20x & x 30。所以表述“20x30或x-100”的C表达式为20x & x 30 | x -100。8结构化程序设计规定的三种基本结构是结构,选择结构和结构。【解】结构化程序设计的三种基本控制结构是顺序结构、选择结构和循环结构。9若有定义语句“int a = 25, b = 14, c = 19;”,以下语句的执行结果是。if(a+=25 & b- = 2 & c+) printf(“*a=%d,b=%d,c=%dn”, a, b, c); else printf(“#a=%d,b=%d,c=%dn”, a, b, c);【解】问题所给的if语句中,条件a+ = 25 & b- = 2 & c+是先求逻辑与的第一个运算分量,它是一个关系式,关系成立。接着判定第二个逻辑与运算分量,又是一个关系式,由于变量b的值是14,b不小于等于2,运算分量的关系式不成立,导致if语句的条件为假,执行else部分。在求if语句的条件时,计算了2个逻辑与分量,使变量a 的值增了1,变量b的值被减了1。所以输出内容是:#a=26,b=13,c=19。10以下两条if语句可合并成一条if语句为。if (a b) printf(“*y = %dn”, y); else printf(“#x = %dn”, x);【解】在以上两条if语句中,两个条件刚巧相反。若将前一个if语句的第一个成分语句与第二个if语句的第二个成分语句合并;第一个if语句的第二个成分语句与第二个if语句的第一个成分语句合并,写成一条if语句如下:if (a = b) x = 1; printf(“#x = %dn”, x); else y = 2; printf(“*y = %dn”, y);11下列程序的功能是输入一个整数,判断是否是素数,若为素数输出1,否则输出0,请为程序填空。main() int i, 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至x/2的整数i测试对x的整除性,若能被其中的某个整数整除,则x是合数,置y的值为0(x不是素数),结束测试循环。若都不能整除,则x为素数。i能否整除x,可用求余运算x%i等于0来判定。所以程序中的空框可填x%i = 0。测试x为素数的代码可写成:y = 1;for(i=2; i =x/2; i+) if(x%i = 0) y = 0; break; 12根据变量定义“static int b5, a3=1,2,3,4,5,6;”,b4=,a12= 。【解】系统规定,静态变量定义时,若未初始化,系统自动给定二进制代码全0的值。所以静态数组b的元素全为0,当然包括b4也为0。静态数组a是两维数组,每行有三个元素,在初始化中给出了六个初值,所以数组a有2行。由于数组的元素按行顺序存储,并按行顺序初始化。前三个值是第一行,后三个值是第二行。a12是第二行的第三列元素,也是a的最后一个元素,所以其值是6。13若在程序中用到“putchar()”函数时,应在程序开头写上包含命令,若在程序中用到“strlen()”函数时,应在程序开头写上包含命令。【解】putchar()是系统提供的头文件stdio.h中定义的宏,所以程序要使用它,必须写上包含命令:#include 。函数strlen()是系统提供的字符串处理函数之一,字符串处理函数的函数原型说明和它们用到的有关常量、数据结构等,在系统提供的头文件string.h中定义,所以使用该函数的程序应在程序开头写上包含命令#include 。14下面程序的功能是输出数组s中最大元素的下标,请填空。main() int k, p,s = 1, -9, 7, 2, -10, 3; for(p = 0, k = p; p sk) printf(“%dn”, k);【解】为要寻找数组中的最大元素的下标,需先预设1个临时最大元素的下标,并顺序逐一考察数组的元素,当发现当前元素比临时最大元素更大时,就用当前元素的下标更新临时最大元素下标。直至考察了数组的全部元素后,这临时最大元素下标就是数组的最大元素下标。通常预设的最大元素下标是数组的首元素下标,考察是从首元素开始顺序向后继元素考察。程序中,存储临时最大元素下标的变量是k,变量p控制顺序考察的循环控制变量。当发现当前元素sp比临时最大元素sk更大时,应该用p更新k。所以在空框处应填入代码“k=p;”。15下面程序的功能是将一个字符串str的内容颠倒过来,请填空。#include main() int i, j, ; char str = “1234567”; for(i = 0, j = strlen(str) ; i j; i+, j+) k = stri; stri = strj; strj = k; printf(“%sn”, str);【解】颠倒一个字符串中的字符,就是首尾对应的元素两两交换。简单地可用两个游标变量i和j,i是前端元素的下标,j是后端元素的下标,交换以这两个变量值为下标的元素stri和strj。开始时,i的值为0,j的值为字符串末元素的下标(字符串长度减1)。每次交换后,i增1,j减1。继续交换的条件是stri还位于strj的前面,即i=a & stri=z。每考察了一个字符后,就要准备考察下一个字符,框3处的语句是让变量i增1,可写成i+,或+i,或i=i+1,或i+=1等。21 以下程序的输出结果是_。main() int a = 10, b = 4, c= 3; if(ab) a = b; if(ac) a = c; printf(“%d, %d, %dn”, a, b, c); 【解】程序中,第一个if语句if(ab) a = b,当ab时,让b值置a,该语句确保a的值不比b小。同样第二个if语句if(a c) a = c,当ac时,让c值置a,使a的值不比c小。实际情况是a本来就比b和c都大,所以a的值没有变,程序输出a、b和c的原来值:10,4,3。22. 以下程序的输出结果是_。 main() int x = 100, a = 10, b = 20, ok1

温馨提示

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

评论

0/150

提交评论