c语言数组习题 .doc
《c语言数组习题 .doc》由会员分享,可在线阅读,更多相关《c语言数组习题 .doc(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数组练习解答1 定义一个名为a的单精度实型一维数组,长度为4,所有元素的初值均为0的数定义语句是_【分析】按照一般数据定义语句的格式,可以直接写出方法一(参看答案);考虑到所有元素均赋初值时可以省略数组长度,可以写出方法二(参看答案);考虑到不省略数组长度,给部分元素赋初值时,所有未赋初值的元素均有空值(对数值型数组来说,初值为0),可以写出方法三(参看答案);考虑到选用静态型,不赋初值所有元素也自动赋予。空值(对数值型数组来说,初值为0),可以写出方法四(参看答案)。【答案】方法一:float a400,00,00,00; 方法二:float a 00,00,00,00; 方法三:float
2、 a4= 00; 方法四: static float 4;2 下列数组定义语句中,错误的是() char x1a; auto char x1=0; static char xl; char xl;【分析】显然答案中给字符型数组赋初值的格式不对(不能直接赋予字符常量,必须用花括号括住),所以备选答案是符合题意的答案。【答案】 3 用冒泡排序法对n个数据排序,需要进行n一1 步。其中第k步的任务是:自下而上,相邻两数比较,小者调上;该操作反复执行nk次。现在假设有4个数据:4、l、3、2要排序,假定4为上、2为下,则利用冒泡排序法执行第2步后的结果是_。【分析】开始排序前的排列执行第1步后的排列执
3、行第2步后的排列 4 1 1 1 4 2 3 2 4 2 3 3 【答案】 l、2、4、34 用选择排序法对n个数据排序,需要进行n1步。其中第k步的任务是:在第k个数据到第n个数据中寻找最小数,和第k个数据交换。现在假设有4个数据:4、1、3、2要排序,则利用冒泡排序法执行第2步后的结果是_。【分析】 开始排序前的排列为: 4 1 3 2 执行第1步后的排列为: 1 4 3 2 执行第2步后的排列为: 1 2 3 4【答案】1、2、3、45 下列数组定义语句中,正确的是() int a=1,2,3,4,5,6; char a23a,b; int a3= 1,2,3,4,5,6; static
4、 int a1,2,3,4,5,6;【分析】C语言规定,二维数组定义时不允许省略第二维的长度,所以备选答案是错误的。C语言还规定,定义字符型数组时不允许直接使用字符常量的方式赋初值,所以备选答案也是错误的。显然备选答案符合题意。【答案】6 定义一个名为s的字符型数组,并且赋初值为字符串123的错误语句是()char s=1,2,3,0 ; char s=123;char s=123n; char s4=1,2,3;【分析】备选答案中省略了数组长度,所以每个元素都赋了初值,共计4个元素,初值依次为l、2、3、0,最后一个元素的值为字符串结束标记,所以数组S中存放的是字符串123,该答案不符合题意
5、(即正确的);备选答案中直接赋予字符串作为初值所以数组s的长度为4,其中的初值是字符串123,不符合题意(即正确的);备选答案中也是给数组s赋予字符串的初值,但是字符串不是123,而是123n,所以该答案符合题意(即错误的);显然答案也不符合题意(即正确的)。下面来分析答案为什么是正确的,该答案给出了数组长度为4,赋初值时仅给前3个元素赋予字符1 、 2、3,第 4个元素没有赋初值,按照 C语言的规定,也有初值,且初值为空值, 对字符型数组来说,空值就是0,即字符率结束标记,所以数组S中存放的也是字符串 123。【答案】7 设有下列数据定义语句,则数组元素xi的值是_。int i 3,x4=
6、1,2,3;【分析】由于i的初值为3,所以xi就是x3。由于数组的下标是从0开始的,所以x3实际上是数组x的第4个元素。从定义语句中可以看出数组x的前3个元素的初值依次为1、2、3,第4个元素没有赋初值,其初值自动设为空值,对整型数组来说,空值是0,显然x3的值是0.【答案】08 设有下列数据定义语句,则 puts(s00)的输出结果是_; puts(s0输出结果是_。char s45=l,0,23,345,40;【分析】首先分析字符型数组s的初值,s的第1行中存放的字符串是1、第2行中存放的符串是23、第3行中存放的字符串是345、第4行中存放的字符串是4。puts()函数的功能是输出从参数
7、处开始存放的字符串中有效字符。按照上的分析,第1个输出的结果是从S00开始的字符串,这个地址对应的就是数s的第1行,所以输出结果为1;第2个输出的结果是从“s”开始的字符串,这个址对应的也是数组s的第1行,所以输出结果也为1。【答案】 1 19 设有下列数据定义语句:char a410=11,22,33,44;则 puts(strcat(a1,a3)的输出结果是_;putS(strcpy(a0,a2)的输出结果是_。【分析】字符数组a共有4行,每行存放一个字符串。这4行的首地址依次为:a0、a1、a2、a3,从这4个地址开始存放的字符串依次为:11、22、33、44。strcat(a1,a3)
8、函数调用的功能是将s3处的字符串连接到al的字符串后面,所以执行该函数调用后的al处的字符串为2244,而该函数的返回值就是a1的首地址,puts()函数的功能就是输出这个地址存放的字符串,由此,第1个输出的结果就是:2244。同样理由可以分析strcpy(a0,a2)的功能是将a2处的字符串(33)复制到a0处,返回a0的地址,puts()输出的就是a0处的字符串,结果为:33。【答案】2244 3310 设有下列数据定义语句: char str210=abc,ABC;则printf(d,strcmp(str1,str0)的输出结果是_;printf(d,strcmp(strlwr(str1
9、,str0),str0)的输出结果是_。【分析】字符型数组str中,从str0开始存放的字符串是abc、从strl开始存放的字符串是ABC。strcmp(strl,str0)是比较strl和str【0处的两个字符串的大小,由于ABC是小于abc的,按照srrcmp函数的功能可知,返回值是一个小于0的整数,这是第1个空的答案。再来分析第2个空的答案,strlwr(strl)函数的功能是将strl处的字符串中大写字母改为小写字母,其返回值是修改后字符串的地址。strcmp(stlwr(sir1),str0)函数的功能是比较strl和str0处的字符串,由于strl处的字符串已经改为小写字母了,所以
10、和 str0处的字符串完全相同,返回值是0,这就是第2个空的答案。答案某个小于0的任意整数 011 下列程序的功能是读取10个实数,然后依次输出前l个实数和、前2个实数和、前9个实数和、前10个实数和。请填写程序中缺少的语句。 main() float f10,X00; int i; for(i=0;i10;i+) scanf( f, fi); for(i=1;i=10;i+) _ printf(sum of NO 2dfn,i,x); 【分析】浏览程序清单后,可以发现前一个次数型循环是输入 10个实数存入数组 f中。后一个次数型循环是计算前i个实数和并存入变量X中,然后再输出这个x的值。程序
11、中所缺少的语句就是实现计算前i个实数和并存入变量X中的。当i等于1时,x要等于f0的值,即fil的值;当i等于2时,x要等于f0 fl的值,即f0fi1的值,此时f0的值已经计算并存入变量x中;当i等于3时,x要等于f0f1f2的值,即f0f1fil的值,此时f0f1的值已经计算并存入变量x中;由此可以推出:前i个值的计算公式为:xxfi1,将这个表达式组成语句就是需要填写的内容。【答案】 x=xfil; 或 xfil;12 运行下列程序的输出结果是() 111ll llll lll 222 main() int a=1,2,3,4, 5 ,i; for( i=1;i 5; i) printf
12、( 1d, ai ai一1); 【分析】首先分析数组a各元素的值,由于是赋初值,很容易看出:a0 1、a12、a45。再分析次数型循环共计执行4次(i1、i2、i3、i4),每次输出1位整数;iai1,当i1时,输出的是211;当i2时,输出的是32l;当i=3时,输出的是43l;当i4时,输出的是541。整个程序的输出结果是1111。【答案】13 下列程序的功能是输入一个5行5列的实数矩阵,然后求出其中的最大数和最小数,并且对调这两个数后,再输出,请填写程序中缺少的语句。main() float f 55,max, x;int i,j,max_l,max_J,min_i,min_J;for(
13、i0;i5;i) for(j0;j5;j) scanf(f,x); fijx; maxminf00;max_imax_imin_imin_j 0;for(i= 0;i5;i) for(j0;j5;j) if(maxfij) maxfij,max_ii,max_jj; if(minfij) _ fmax_imax_jmin;fmin_imin_jmax; for(i0;i5;i) printf(n); for(j0;j5;j) printf(82f,fij); 【分析】首先宏观上阅读程序,可以看出程序的基本结构是:用双重次数型循环读取5行5列矩阵的元素值存入二维数组f中;寻找矩阵中的最大数和最小
14、数;交换最大数和最小数;输出交换后的矩阵元素值。需要填写的语句属于第2个部分。现在来仔细分析这个部分的程序。通常寻找最大数(或最小数)的算法是首先假定最前面的数是最大数(或最小数),并记录该数及其在数组中的下标,然后依次处理所有元素,若当前处理的元素大于(小于)最大数(最小数),则重新记录新的最大数(最小数)及其下标。从本程序清单来看,的确是采用了这个算法,由于是同时求最大数和最小数,所以用max、max_i、max_j分别记录当前的最大数及其行列下标,用min、min_i、min_j分别记录当前的最小数及其行列下标。在二重循环的循环体中有两条单分支语句,前一个单分支语句的功能很清楚,判断当前
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- c语言数组习题 语言 数组 习题
限制150内