【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc

上传人:lawfemale396 文档编号:1332056 上传时间:2019-10-17 格式:DOC 页数:10 大小:59.50KB
下载 相关 举报
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc_第1页
第1页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc_第2页
第2页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc_第3页
第3页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc_第4页
第4页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷14及答案解析.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、国家二级 C语言机试(函数和数组)模拟试卷 14及答案解析(总分:56.00,做题时间:90 分钟)一、选择题(总题数:28,分数:56.00)1.在一个 C源程序文件中所定义的全局变量,其作用域为(分数:2.00)A.由具体定义位置和 extern说明来决定范围B.所在程序的全部范围C.所在函数的全部范围D.所在文件的全部范围2.有以下程序 void fun2(char a,char b) main() printf(“cc“,a,b); fun1(); char a=A,b=B;printf(“cc“,a,b); void fun1() fun2(E,F); a=C;b=D; 程序的运行结

2、果是(分数:2.00)A.A B E FB.C D E FC.A B C DD.C D A B3.有以下程序 #include main() int k:4,m=1,p: fun(int a,int b)int static m=0,i=2;p=fun(k,m); i=i+m+1;printf(“0d,“,p); m=i+a+b;p=fun(k,m); return m;printf(“dn“,p); 程序运行后的输出结果是(分数:2.00)A.8,17B.7,16C.8,8D.7,174.有以下程序 #include func(int n) void main() static int nu

3、m=1; func(3);func(4);printf(“n“); num=num+n;printf(“d“,num); 程序运行后的输出是(分数:2.00)A.45B.35C.48D.345.有以下程序 fun(int x,int y) main() static int m=0,i=2; intj=1,m=1,k; i+=m+1;m=i+x+y;return m; k=fun(j,m);printf(“d,“,k); k=fun(j,m);printf(“dn“,k); 执行后的输出结果是(分数:2.00)A.5,5B.5,11C.11,11D.11,56.在 C语言中,只有在使用时才占用

4、内存单元的变量,其存储类型是(分数:2.00)A.extern和 registerB.auto和 staticC.static和 registerD.auto和 register7.有以下程序 #include main()int i,s=1: int fun()static int x=1; for(i=l;i=3;i+) x*=2; s*=fun(); return x; printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.0B.10C.30D.648.有以下程序 #include int flint n); main()int a=3,s; int flint n

5、)static int a=1; s=f(a);n+=a+; s=s+f(a); return n; printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.9B.8C.7D.109.有以下程序 #include int fun()static int x=1; main()int i,s=1; x+=1; for(i=1;i=5;i+)s+=fun(); return x;printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.11B.21C.6D.12010.有以下程序 int fun(int x,int n) main() static int s

6、um=0,i; int a=1,2,3,4,5,b=6,7,8,9,s=0; for(i=0;iA.50B.45C.60D.5511.有以下程序 int f(int m) main()int n=0; static int n=0;printf(“d,“,(f+n); n+=m;return n; printf(“dn“,f(n+); 程序运行后的输出结果是(分数:2.00)A.11B.1,2C.2,3D.3,312.有以下程序 #include main() int fun() int i,s=1; static int x=1: for(i=1;iA.4B.1C.0D.813.有下列程序:

7、 int a=4; int f(int n) main() int t=0; static int a=5; int s=a,i=0; if(n2)int a=6;t+=a+; for(;iA.28B.24C.32D.3614.已有定义:char a=“xyz“,b=x,y,z;,以下叙述中正确的是(分数:2.00)A.数组 a和 b长度相同B.a数组长度小于 b数组长度C.a数组长度大于 b数组长度D.上述说法都不对15.若有语句:char*line5;,以下叙述中正确的是(分数:2.00)A.定义 line是一个数组,每个数组元素是一个基类型为 char的指针变量B.定义 line是一个指

8、针变量,该变量可以指向一个长度为 5的字符型数组C.定义 line是一个指针数组,语句中的*号称为间址运算符D.定义 line是一个指向字符型函数的指针16.若有定义语句:int m=5,4,3,2,1,i=4;,则下面对 m数组元素的引用中错误的是(分数:2.00)A.m-iB.m2*2C.mm0/D.mmi/17.若有定义语句:double x5=10,20,30,40,50,*p=x;则错误引用 x数组元素的是(分数:2.00)A.*pB.x5C.*(p+1)D.*x18.若要定义一个具有 5个元素的整型数组,以下错误的定义语句是(分数:2.00)A.int a5=0;B.int b=0

9、,0,0,0,0;C.int c2+3D.int i=5,di;19.以下能正确定义一维数组的选项是(分数:2.00)A.int a5=0,1,2,3,4,5;B.char a=0,1,2,3,4,5;C.char a=A,B,C;D.int a5=“0123“;20.有以下程序 void fun(int a,int n)int i,t;for(i=0;in2;i+) t=ai; ai=an-1-i; an-1-i=t; main() int k10=1,2,3,4,5,6,7,8,9,10,i; fun(k,5); for(i=2;i8;i+)printf(“d“,ki); printf(“

10、n“); 程序的运行结果是(分数:2.00)A.876543B.321678C.1098765D.34567821.下列定义数组的语句中,正确的是(分数:2.00)A.int N=10;int xN;B.#define N 10 int xN;C.int x010;D.int x;22.有以下程序 #include void main() int a=2,3,5,4,i; for(i=0;iA.2 0 5 0B.3 3 4 4C.3 0 4 0D.0 3 0 423.有以下程序 #include main() void fun(int a,int b) int c10=1,2,3,4,5,6,

11、7,8,9,0),i; int t; for(i=0;iA.2,1,4,3,6,5,8,7,0,9,B.0,9,8,7,6,5,4,3,2,1,C.1,2,3,4,5,6,7,8,9,0,D.0,1,2,3,4,5,6,7,8,9,24.有下列程序: main() int i,s=0,t=1,2,3,4,5,6,7,8,9; for(i=0;iA.20B.45C.36D.2525.下列选项中,能正确定义数组的语句是(分数:2.00)A.int num;B.int N=2008;int numN;C.int num02008;D.#define N 2008 int numN;26.若要求定义具

12、有 10个 int型元素的一维数组 a,则以下定义语句中错误的是(分数:2.00)A.#define n 5 int a2*n;B.int a5+5;C.#define N 10 int aN;D.int n=10,an;27.下列程序中函数 f的功能是:当 flag为 1时,进行由小到大排序;当 flag为 0时,进行由大到小排序 void flint b,int n,int flag) main() int ij,t; int a10=5,4,3,2,1,6,7,8,9,10,i; for(i=0;ibj:biA.1,2,3,4,5,6,7,8,9,10,B.3,4,5,6,7,2,1,8

13、,9,10,C.5,4,3,2,1,6,7,8,9,10,D.10,9,8,7,6,5,4,3,2,1,28.有以下程序 #include main() int s12=1,2,3,4,4,3,2,1,1,1,2,3),c5=0,i; for(i=0;iA.4 3 3 2B.2 3 4 4C.1 2 3 4D.1 1 2 3国家二级 C语言机试(函数和数组)模拟试卷 14答案解析(总分:56.00,做题时间:90 分钟)一、选择题(总题数:28,分数:56.00)1.在一个 C源程序文件中所定义的全局变量,其作用域为(分数:2.00)A.由具体定义位置和 extern说明来决定范围 B.所在程

14、序的全部范围C.所在函数的全部范围D.所在文件的全部范围解析:解析:全局变量是在函数外部任意位置上定义的变量,它的作用域是从变量定义的位置开始,到整个源文件结束止。在同一编译单位内用 extern说明符扩展全局变量的作用域(当全局变量定义在后,引用它的函数在前时,应该在引用它的函数中用 extern对此全局变量进行说明,以便通知编译程序:该变量是一个己在外部定义了的全局变量,已经分配了存储单元,不需要再为它分配存储单元。这时全局变量的作用域从 extern说明处起,延伸到该函数末尾)。当一个程序由多个编译单位构成,并且在每个文件中均需要引用同一个全局变量,这时只在其中一个文件中定义所有的全局变

15、量,而在其他用到这些全局变量的文件中用 extem对这些变量进行说明。2.有以下程序 void fun2(char a,char b) main() printf(“cc“,a,b); fun1(); char a=A,b=B;printf(“cc“,a,b); void fun1() fun2(E,F); a=C;b=D; 程序的运行结果是(分数:2.00)A.A B E FB.C D E F C.A B C DD.C D A B解析:解析:在 fun1()函数之前定义了全局字符变量 a和 b。这两个变量的作用域是从其定义处到整个程序结束。在 fun1()函数之内定义了两个变量 a和 b,并

16、且分别初始化为字符C和D。在 C语言中,若全局变量和某个函数中的局部变量同名,则在该函数中此全局变量被屏蔽,在该函数内访问的是局部变量,与同名的全局变量不发生任何关系。所以在主函数中,执行 fun1()后,变量 a、b 的值分别等于C、D,打印输出 CD,接着执行 fun2(E,F)语句,变量 a、b 的值变为E、F并输出。3.有以下程序 #include main() int k:4,m=1,p: fun(int a,int b)int static m=0,i=2;p=fun(k,m); i=i+m+1;printf(“0d,“,p); m=i+a+b;p=fun(k,m); return

17、 m;printf(“dn“,p); 程序运行后的输出结果是(分数:2.00)A.8,17 B.7,16C.8,8D.7,17解析:解析:本题考查了静态变量以及局部变量的同名问题。主函数中调用 fun函数两次,第一次调用fun(4,1),形参 a和 b接收以后,i 值为 3,m 的值为 8,调用结束返回 8存放到 p中并且输出 p的值为8,除了静态变量 m和 i,变量 a,b 撤销。第二次调用 fun(4,1),接收实参值以后,i 为 3+8+1,而 m为 12+4+1,即输出函数值 17。4.有以下程序 #include func(int n) void main() static int

18、num=1; func(3);func(4);printf(“n“); num=num+n;printf(“d“,num); 程序运行后的输出是(分数:2.00)A.45B.35C.48 D.34解析:解析:在函数 func(int n)中定义了局部静态变量 num,其初始值等于 1,所以在主函数中执行func(3),输出 4,此时静态变量 num的值等于 4,当退出函数 func(3)时,其值不会丢失,所以当在执行func(4)时,输出 8。5.有以下程序 fun(int x,int y) main() static int m=0,i=2; intj=1,m=1,k; i+=m+1;m=i

19、+x+y;return m; k=fun(j,m);printf(“d,“,k); k=fun(j,m);printf(“dn“,k); 执行后的输出结果是(分数:2.00)A.5,5B.5,11 C.11,11D.11,5解析:解析:子函数 fun(int x,int y),将变量 m和 i声明为局部静态变量,因此第 1次调用主函数后,局部静态变量 m和 i的值为 5和 3,第 1次函数调用结束时,它们的值不释放保持不变,所以第 2次调用时,局部静态变量 m和 i的初始值分别为 5和 3,即在执行“i+=m+1”时,i 的值为 9,因此最终 m的值为 11。6.在 C语言中,只有在使用时才占

20、用内存单元的变量,其存储类型是(分数:2.00)A.extern和 registerB.auto和 staticC.static和 registerD.auto和 register 解析:解析:在 C语言中,动态变量(auto)存储在内存中的动态存储区,在程序运行中,只有当调用变量所在的函数时,系统才临时给变量分配内存单元:全局变量(extem)一经定义,系统为其分配固定的内存单元;静态变量(static),编译系统为其分配固定的存储空间:寄存器变量(register)不保存在内存上,而是直接存储在 CPU的寄存器中。7.有以下程序 #include main()int i,s=1: int

21、fun()static int x=1; for(i=l;i=3;i+) x*=2; s*=fun(); return x; printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.0B.10C.30D.64 解析:解析:本题考查了静态局部变量,该局部变量的值在函数调用结束后如果不消失而保留原值。函数fun的功能返回 2的乘方,主函数 fun函数调用 3次,因此第一次 s累乘 2,第二次累乘 4,第三次累乘8,即为 2*4*8,值为 64。8.有以下程序 #include int flint n); main()int a=3,s; int flint n)static i

22、nt a=1; s=f(a);n+=a+; s=s+f(a); return n; printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.9 B.8C.7D.10解析:解析:在主函数中第一次调用 f(a)时,得到变量 s的值等于 4,在第二次调用 f(a)时,在子函数f中由于变量 a是一个局部静态变量,所以这次其值等于 2,因而在主函数中第二次调用 f(a)后,其返回值等于 5,最后变量 s的值等于 9。9.有以下程序 #include int fun()static int x=1; main()int i,s=1; x+=1; for(i=1;i=5;i+)s+=fu

23、n(); return x;printf(“dn“,s); 程序运行后的输出结果是(分数:2.00)A.11B.21 C.6D.120解析:解析:这道试题主要考查了局部静态变量的应用。在函数 fun()中定义了局部静态变量整型 x,其初值等于 1,在主函数中循环执行 5次,第一次变量 s的值等于 3,变量 x的值等于 2,第二次变量 s的值等于 6,变量 x的值等于 3,第三次变量 s的值等于 10,变量 x的值等于 4,第四次变量 s的值等于15,变量 x的值等于 5,第五次变量 s的值等于 21,变量 x的值等于 6。10.有以下程序 int fun(int x,int n) main()

24、 static int sum=0,i; int a=1,2,3,4,5,b=6,7,8,9,s=0; for(i=0;iA.50B.45C.60 D.55解析:解析:在函数 int fun(int x,int n)的定义中,变量 sum使用了 static修饰符,这说明了变量 sum为一个静态局部变量。由于在整个程序运行期间,静态局部变量在内存中的静态存储区中占据着永久的存储单元。即使退出函数之后,下次再进入该函数时,静态局部变量继续使用原来存储单元中原来的值。函数 intfun(int x,int n)的功能是求出数组 x各个元素的和。所以在主函数中,调用函数Fun(a,5)后,变量 su

25、m=1+2+3+4+5=15,当再次调用 Fun(b,4)后,变量 sum=15+6+7+8+9=45,所以s=15+45=60。11.有以下程序 int f(int m) main()int n=0; static int n=0;printf(“d,“,(f+n); n+=m;return n; printf(“dn“,f(n+); 程序运行后的输出结果是(分数:2.00)A.11B.1,2 C.2,3D.3,3解析:解析:由于在函数 f中,变量 n为静态局部变量,所以在主函数中第一次调用函数 f后,变量 n的值等于 1,当第二调用函数 f时,在函数 f的内部静态局部变量 n的值仍然保留等

26、于 1,所以返回函数值等于 2。12.有以下程序 #include main() int fun() int i,s=1; static int x=1: for(i=1;iA.4 B.1C.0D.8解析:解析:在子函数 fun()中定义局部静态变量 x,其初值等于 1,然后再把其值扩大 1倍后返回。在主函数中执行 for循环语句 2次,调用函数 fun()两次,所以变量 s的值等于 4。这里要强调的一点是当函数 fun()执行完毕后,局部静态变量 x的值不会丢失,仍然有效。13.有下列程序: int a=4; int f(int n) main() int t=0; static int a

27、=5; int s=a,i=0; if(n2)int a=6;t+=a+; for(;iA.28 B.24C.32D.36解析:解析:程序中定义了全局整型变量 a=4。在 intf(int n)函数中定义了局部静态整型变量并进行了初始化即 static inta=5。在 int f(int n)函数中对 n是否是偶数进行判断,如果 n是奇数,则函数的返回值为 11,局部静态整型变量 a=6:如果 n是偶数,则函数的返回值为 12,局部静态整型变量 a=6。所以在 main()函数中循环首先执行 s+=f(0)语句,而 f(0)返回值 12,所以第一次循环结束 s的值等于4+12=16:第二次开

28、始执行 f(1)时,在 f(1)中执行“if(n2)int a=6:t+=a+;”和“return t+a+;”这两条语句,这时 t=6,a=6(静态局部变量第一次循环后其值加 1值不释放,执行第二次循环量,其值仍有效),所以 f(1)的返回值等于 12。再在主函数中执行 s+=f(1)语句。即 16+12=28。14.已有定义:char a=“xyz“,b=x,y,z;,以下叙述中正确的是(分数:2.00)A.数组 a和 b长度相同B.a数组长度小于 b数组长度C.a数组长度大于 b数组长度 D.上述说法都不对解析:解析:本题考查字符数组的定义。char“a=“xyz“,b=x,yz;”定义

29、了两个字符数组 a和 b,a 数组存放的是一个字符串,字符串以“0”作为结束标志,数组 a的长度必须加上结束符长度 1,因此数组 a的长度为 4。数组 b中有三个元素,长度为 3。15.若有语句:char*line5;,以下叙述中正确的是(分数:2.00)A.定义 line是一个数组,每个数组元素是一个基类型为 char的指针变量 B.定义 line是一个指针变量,该变量可以指向一个长度为 5的字符型数组C.定义 line是一个指针数组,语句中的*号称为间址运算符D.定义 line是一个指向字符型函数的指针解析:解析:本题考查指针数组的定义。本题中 line是一个指针数组,有 5个元素,每个元

30、素都是一个指针变量。16.若有定义语句:int m=5,4,3,2,1,i=4;,则下面对 m数组元素的引用中错误的是(分数:2.00)A.m-iB.m2*2C.mm0/ D.mmi/解析:解析:本题考查数组的使用。m 是一个一维数组,长度为 5,因此下标范围是 0-4。选项 A中一是先自减,然后使用 i,因此访问的是元素 m3:选项 B访问的是元素 m4:选项 C中内部的 m0值是5,因此实际访问是的 m5,下标超出范围:选项 D中 mi的值是 1,访问元素 m1。17.若有定义语句:double x5=10,20,30,40,50,*p=x;则错误引用 x数组元素的是(分数:2.00)A.

31、*pB.x5 C.*(p+1)D.*x解析:解析:本题考查数组和指向数组的指针。x 是一个一维 double类型的数组,长度为 5,下标范围是0-4,指针 p指向数组 x。选项 A中*p 是取数组首元素 x0的值;选项 B下标超出范围;选项 C,p+1 表示 x1的地址,因此*(p+1)是取 x1元素值;选项 D中,数组名 x本身代表数组的首地址,因此*x 表示取元素 x0的值。18.若要定义一个具有 5个元素的整型数组,以下错误的定义语句是(分数:2.00)A.int a5=0;B.int b=0,0,0,0,0;C.int c2+3D.int i=5,di; 解析:解析:本题考查一维数组的

32、定义,C 语言中一维数组的定义方式为:类型说明符 数组名常量表达式;。 选项 A正确;选项 B初始化了 5个元素,因此数组长度为 5;选项 C常量表达式 2+3的值为 5,正确;选项 D数组长度不是常量表达式,错误。19.以下能正确定义一维数组的选项是(分数:2.00)A.int a5=0,1,2,3,4,5;B.char a=0,1,2,3,4,5; C.char a=A,B,C;D.int a5=“0123“;解析:解析:本题考查一维数组的定义,C 语言中一维数组的定义方式为:类型说明符 数组名常量表达式;。 选项 A定义的数组长度为 5,大括号里面的元素个数为 6,超过数组长度,错误;选

33、项 B正确,编译器会根据初始化元素的个数自动计算数组的长度。选项 C中没有使用“”,不能定义一维数组:选项 D中数组元素的初始化必须使用大括号。20.有以下程序 void fun(int a,int n)int i,t;for(i=0;in2;i+) t=ai; ai=an-1-i; an-1-i=t; main() int k10=1,2,3,4,5,6,7,8,9,10,i; fun(k,5); for(i=2;i8;i+)printf(“d“,ki); printf(“n“); 程序的运行结果是(分数:2.00)A.876543B.321678 C.1098765D.345678解析:解

34、析:函数 fun(int a,int n)的功能是实现整型数组 a元素的逆置操作。在主函数中当执行fun(k,5)时,对 k10中的子数组 k5=1,2,3,4,5的首尾元素进行逆置,此时 k10=5,4,3,2,1,6,7,8,9,10。所在循环语句中输出从第 27个数组元素时,其值分别为321678。21.下列定义数组的语句中,正确的是(分数:2.00)A.int N=10;int xN;B.#define N 10 int xN; C.int x010;D.int x;解析:解析:数组说明的一般形式为:类型说明符数组名常量表达式;其中类型说明符可以是任一种基本数据类型或构造数据类型,数组

35、名是定义的数组标识符。常量表达式表示数据元素的个数,也就是数组的长度,必须是整型常量。22.有以下程序 #include void main() int a=2,3,5,4,i; for(i=0;iA.2 0 5 0B.3 3 4 4C.3 0 4 0 D.0 3 0 4解析:解析:在主函数的 for循环语句中,当循环变量 i的值等于 0,2 时,执行 switch中的 case 0语句,分别对数组元素 a0和 a2加 1和减 1,所以 a0的值等于 3,a2等于 4。当循环变量 i的值等于1,3 时,执行 switch中的 case 1语句,把数组元素 a1和 a3的值赋为 0。所以输出数组

36、 a的元素,其结果为 3040。23.有以下程序 #include main() void fun(int a,int b) int c10=1,2,3,4,5,6,7,8,9,0),i; int t; for(i=0;iA.2,1,4,3,6,5,8,7,0,9,B.0,9,8,7,6,5,4,3,2,1,C.1,2,3,4,5,6,7,8,9,0, D.0,1,2,3,4,5,6,7,8,9,解析:解析:C 语言规定,实参变量对形参变量的数据传递是“值传递”,即单向传递,只由实参传给形参,而不能由形参传回来给实参。在调用函数时,给形参分配存储单元,并将实参对应的值传递给形参,调用结束后,形

37、参单元被释放,实参单元仍保留并维持原值。由此可知,在本题中,函数 fun(int a,int b)的功能是实现形参整形变量 a和 b值的互换。当在主函数中调用 fun(ci,ci+1)时,把实参变量 ci和 ci+1的值赋给形参变量 a和 b,执行完函数 fun(ci,ci+1)时,形参变量 a和 b的值发生了互换,实参变量 ci和 ci+l的值并没有发生互换,所以输出的值为1,2,3,4,5,6,7,8,9,0。24.有下列程序: main() int i,s=0,t=1,2,3,4,5,6,7,8,9; for(i=0;iA.20B.45C.36D.25 解析:解析:本题在主函数中定义了一

38、维整型数组 t=1,2,3,4,5,6,7,8,9;然后在 for循环语句中自变量 i从 0开始,每次自加 2,执行 s+=*(t+i)语句,因为 C语言规定数组名代表数组的首地址,也就是第一个元素的地址。因此*(t+i)代表数组的第 i+1个元素。所以程序运行的结果是1+3+5+7+9=25,即变量 s的值等于 25。25.下列选项中,能正确定义数组的语句是(分数:2.00)A.int num;B.int N=2008;int numN;C.int num02008;D.#define N 2008 int numN; 解析:解析:在定义一维数组时,数组的下标应该是一个确定的整数值。要注意的

39、是在定义二维数组时,其第一维下标可以省略,但第二维下标不能省略。26.若要求定义具有 10个 int型元素的一维数组 a,则以下定义语句中错误的是(分数:2.00)A.#define n 5 int a2*n;B.int a5+5;C.#define N 10 int aN;D.int n=10,an; 解析:解析:在 C语言中,定义一维数组的语句形式为:类型名 数组名整型常量表达式。在选项 D中,n是一个整型的变量。27.下列程序中函数 f的功能是:当 flag为 1时,进行由小到大排序;当 flag为 0时,进行由大到小排序 void flint b,int n,int flag) mai

40、n() int ij,t; int a10=5,4,3,2,1,6,7,8,9,10,i; for(i=0;ibj:biA.1,2,3,4,5,6,7,8,9,10,B.3,4,5,6,7,2,1,8,9,10, C.5,4,3,2,1,6,7,8,9,10,D.10,9,8,7,6,5,4,3,2,1,解析:解析:主函数中进行了两次 f函数的调用。第一次传递给形参数组 b的地址为元素 a2的地址,n接收数据位 5,因此数组 b中元素为 3,2,1,6,7,此时 flag的值为 0,进行由大到小排序,而数组 b和实参数组 a共用一段存储空间,第一次调用结束以后,数组 a的值为5,4,7,6,3

41、,2,1,8,9,10。第二次调用 f函数,形参数组接收实参数组 a的首地址,取 5个元素,由小到大排序,调用结束以后,数组 a的值为 3,4,5,6,7,2,1,8,9,10。28.有以下程序 #include main() int s12=1,2,3,4,4,3,2,1,1,1,2,3),c5=0,i; for(i=0;iA.4 3 3 2 B.2 3 4 4C.1 2 3 4D.1 1 2 3解析:解析:本题考查 for语句的循环控制,首先定义了两个数组并赋予了初始值,第一个 for循环语句循环 12次遍历 s数组的各个元素,将 s中的原素值作为 c数组中的下标,使相应的值自加。例如当i=0,cs0/+为 c1+,其值变为 1,当执行 i=1,2,11 后,c1、c2、c3、c4分别为4、3、3、2,故选项 A为正确的运行结果。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1