c语言数组习题集Word格式.docx
《c语言数组习题集Word格式.docx》由会员分享,可在线阅读,更多相关《c语言数组习题集Word格式.docx(11页珍藏版)》请在冰豆网上搜索。
A.数组第1个元素的首地址B.数组第2个元素的首地址
C.数组所有元素的首地址D.数组最后1个元素的首地址
(6)若有以下数组说明,则数值最小的和最大的元素下标分别是(B)
inta[12]={1,2,3,4,5,6,7,8,9,10,11,12};
A.1,12B.0,11C.1,11D.0,12
(7)若有以下说明,则数值为4的表达式是(D)。
inta[12]={1,2,3,4,5,6,7,8,9,10,11,12};
charc=’a’,d,g;
A.a[g-c]B.a[4]C.a['
d'
-'
c'
]D.a['
-c]
(8)设有定义:
chars[12]="
string"
;
则printf("
%d\n"
strlen(s));
的输出是(A)。
A.6B.7C.11D.12
(9)设有定义:
则printf("
%d\n"
sizeof(s));
的输出是(B)。
(10)合法的数组定义是(A)。
A.chara[]="
string"
B.inta[5]={0,1,2,3,4,5};
C.chara="
D.chara[]={0,1,2,3,4,5}
(11)合法的数组定义是(D)。
A.inta[3][]={0,1,2,3,4,5};
B.inta[][3]={0,1,2,3,4};
C.inta[2][3]={0,1,2,3,4,5,6};
D.inta[2][3]={0,1,2,3,4,5};
(12)下列定义的字符数组中,输出printf("
%s\n"
str[2]);
的输出是(C)。
staticstr[3][20]={"
basic"
"
foxpro"
windows"
A.basicB.foxproC.windowsD.输出语句出错
(14)下列各语句定义了数组,其中哪一个是不正确的(C)。
A.chara[3][10]={"
China"
"
American"
Asia"
B.intx[2][2]={1,2,3,4};
C.floatx[2][]={1,2,4,6,8,10};
D.intm[][3]={1,2,3,4,5,6};
(15)数组定义为inta[3][2]={1,2,3,4,5,6},值为6的数组元素是(B)。
A.a[3][2]B.a[2][1]C.a[1][2]D.a[2][3]
(16)下面的程序中哪一行有错误(A)。
#includemain()
{floatarray[5]={0.0};
//第A行
inti;
for(i=0;
i<
5;
i++)scanf("
%f"
&
array[i]);
for(i=1;
i++)array[0]=array[0]+array[i];
//第B行
printf("
%f\n"
array[0]);
//第C行}
A.第A行B.第B行C.第C行D.没有
(17)下面哪一项是不正确的字符串赋值或赋初值的方式(A)。
A.char*str;
str="
B.charstr[7]={'
s'
'
t'
r'
i'
n'
g'
C.charstr1[10];
str1="
D.charstr1[]="
str2[]="
12345678"
(18)若有以下说明和语句,则输出结果是哪一项(D)。
(strlen(s)为求字符串s的长度的函数)
chars[12]="
abook!
"
printf("
%d"
A.12B.8C.7D.11
(19)若有以下说明和语句,则输出结果是(C)。
charsp[]="
\t\v\\\0will\n"
strlen(sp));
A.14B.3C.9D.字符串中有非法字符
(20)若有以下说明和语句,则输出结果是(C)。
charstr[]="
\"
c:
\\abc.dat\"
%s"
str);
A.字符串中有非法字符B.\"
C."
\abc.dat"
D."
\\abc.dat"
2.填空题
(1)C语言中,数组的各元素必须具有相同的(类型名),元素的下标下限为(0),下标必须是正整数、0、或者(变量)。
但在程序执行过程中,不检查元素下标是否()。
(2)C语言中,数组在内存中占一片()的存储区,由()代表它的首地址。
数组名是一个()常量,不能对它进行赋值运算。
(3)执行staticintb[5],a[][3]={1,2,3,4,5,6};
后,b[4]=(),a[1][2]=()。
(4)设有定义语句staticinta[3][4]={{1},{2},{3}};
则a[1][0]值为(),a[1][1]值为(),a[2][1]的值为()。
(5)如定义语句为chara[]="
b[]="
95"
,
语句printf("
strcat(a,b));
的输出结果为。
(6)根据以下说明,写出正确的说明语句:
men是一个有10个整型元素的数组。
step是一个有4个实型元素的数组,元素值分别为1.9,-2.33,0,20.6。
grid是一个二维数组,共有4行,10列整型元素。
intgrid[4][10];
(7)array是一个一维整形数组,有10个元素,前6个元素的初值是9,4,7,49,32,-5,正确的说明语句为:
。
该数组下标的取值范围是从___到___(从小到大)。
用scanf函数输入数组的第二个元素表示为。
用赋值语句把39存入第一个元素表示为:
把第六个和第四个元素之和存入第一个元素表示为:
。
(8)写出以下初始化数组的长度:
①intchn[3];
数组chn的长度为___。
②floatisa[]={1.0,2.0,3.0,4.0,5.0};
数组isa的长度为___。
③intdoom[8];
数组doom的长度为___。
④floatpci[4][2];
数组pci的长度为___。
⑤intast[3][3];
数组ast的长度为___。
⑥intatt[3][4];
数组att的长度为___。
⑦floatdell[][3]={{1,4,7},{2,5},{3,6,9}};
数组dell的长度为___。
(9)若有以下整型的a数组,数组元素和它们得值如下所示:
数组元素:
a[0]a[1]a[2]a[3]a[4]a[5]a[6]a[7]a[8]a[9]元素的值:
941282107513①请写出对该数组的说明,并赋以上初值。
②该数组的最小下标值为___,最大下标值为___。
③写出下面各式的值:
a[a[9]]的值为___;
a[a[4]+a[8]]的值为___。
(10)字符串"
ab\n\\012/\\\"
的长度为___。
3.判断题
()
(1)C允许对数组的大小作动态定义,即可用变量定义数组的大小。
()
(2)字符数组不要求它的最后一个字符为‘\0’,甚至可以不包含‘\0’。
()(3)数组定义inta[10];
也可以写成inta(10);
()(4)在对全部数组元素赋初值时,可以不指定数组长度。
()(5)定义s为5×
6(5行6列)的数组可写成floata[5,6];
()(6)数组定义inta[10];
表示数组名为a,此数组有10个元素。
()(7)数组定义inta[10];
表示数组名为a,此数组有10个元素,第10个元素为a[10]。
()(8)staticcharc[]={“abook”};
与staticcharc[]=“abook”;
等价。
()(9)staticcharc[]={'
a'
'
'
b'
o'
k'
与staticcharc[]={'
()(10)设已有说明:
staticcharc1[10],c2[10];
下面程序片段是合法的。
c1={“book”};
c2=c1;
4.程序填空题
(1)输入20个数,输出它们的平均值,输出与平均值之差的绝对值为最小的数组元素。
请填空。
#includevoidmain()
{floata[20],pjz=0,s,t;
inti,k;
for(i=0;
20;
i++){pjz+=a[i];
}
s=fabs(a[0]-pjz);
i++)
if(fabs(a[i]-pjz)<
s)
{s=fabs(a[i]-pjz);
t=a[i];
}
}
(2)以下程序以每行10个数据的形式输出a数组,请填空。
voidmain()
{inta[50],i;
输入50个整数:
);
i<
50;
i++)scanf("
);
=50;
i++)
{if()printf("
%3d\n"
);
printf("
%3d"
a[i-1]);
}}
(3)下面程序的功能是输出数组s中最大元素的下标,请填空。
voidmain()
{intk,p;
ints[]={1,-9,7,2,-10,3};
for(p=0,k=p;
p<
6;
p++)
if(s[p]>
s[k]);
k);
}
(4)这个程序输入了20个数存放在一个数组中,并且输出其中最大者与最小者、20个数的和及它们的平均值。
voidmain()
{chararray;
intmax,min,a