覆盖学起Plus、超星学习通等平台的全学科作业答案、历年真题与考试速查系统
【百年教育职业培训中心】程序设计(王苗)-章节资料考试资料-河北大学
招生简章 2025-06-15 04:56:57 0 0
中国大学MOOC作业考试答案

想要快速找到正确答案?

立即关注 超新尔雅学习通微信公众号,轻松解决学习难题!

超新尔雅学习通
扫码关注

作业辅导
扫码关注
论文指导
轻松解决学习难题!

报名本机构合作学校,赠送复习资料,复习课程,确保录取。并且可以申请学校奖学金500元~1500元不等!

codeblocks介绍——从Hello World开始

1、【单选题】#include stdio.h是

A、编译预处理指令

B、语句

C、函数

D、程序入口

debug

1、【单选题】codeblocks中运行到下一步(next line)的快捷键是

A、F7

B、F5

C、F8

D、F11

变量在内存中所占的字节数

1、【单选题】C语言用sizeof计算变量在内存中的字节数,其中sizeof是()

A、函数

B、运算符

C、标识符

D、语句

宏常量与const常量

1、【单选题】宏定义是()

A、一条语句

B、一种编译预处理指令

C、一个标识符

D、一个变量

2、【判断题】const常量有数据类型。

A、正确

B、错误

练兵区——编程题——不计入总分

第1周测验

1、【单选题】下列选项中,合法的C语言标识符是

A、_a1

B、width.x

C、

D、abc123

E、123abc

F、o*k

G、a?

H、a+b

I、%a

J、b!

2、【单选题】以下不适合定义为用户标识符的是

A、int

B、a2

C、def2

D、_3com_

E、PI

F、Source

G、abc

3、【单选题】#include stdio.h是

A、编译预处理指令

B、语句

C、函数

D、什么都不是

E、有语法错误

4、【单选题】在windows下,程序编译链接后形成的可执行文件是

A、.obj文件

B、.exe文件

C、.o文件

D、.c文件

E、.h文件

5、【单选题】程序编译链接后显示 0 error,0 warning 代表

A、程序中没有语法错误

B、程序是正确的

C、程序是不正确的

D、程序中可能存在语法错误

E、程序中有语义错误

6、【单选题】用8位无符号二进制数能表示的最大十进制数为

A、255

B、127

C、128

D、256

7、【单选题】关于可执行文件说法正确的是

A、可执行文件是编译链接后生成的文件

B、可执行文件就是源代码文件

C、可执行文件后缀为.obj

D、可执行文件就是main.c文件

8、【单选题】若变量a是int类型,并执行了语句:a='A'+1.6;,则正确的叙述是

A、'A'+1.6的结果是浮点型

B、a的值还是整型

C、a的值是字符C

D、a的值是浮点型

E、不允许字符型和浮点型相加

9、【单选题】C语言用sizeof计算变量在内存中的字节数,其中sizeof是()

A、运算符

B、一元运算符

C、只需要一个操作数的运算符

D、函数

E、语句

F、标识符

G、变量

10、【单选题】以下不属于Codeblocks中用于调试程序的工具是

A、run

B、build

C、run to cursor

D、next line

E、stop debugger

F、watches

11、【单选题】程序的开发步骤中不包括

A、撰写文档

B、运行程序

C、编译链接

D、程序测试

E、编辑(编写代码)

12、【单选题】下列说法中错误的是()

A、尾数决定了实数的表数范围,阶码决定了实数的表数精度。

B、内存是按位编址的。

C、有符号和无符号整数的表数范围是相同的。

D、int型在所有的计算机上都占4个字节的存储单元。

E、编译器按变量定义的类型对不同类型的变量分配不同大小的内存空间。

F、内存是按字节编址的。

G、对于同样的尾数,阶码的值越大,则浮点数所表示的数值的绝对值就越大。

H、sizeof是编译时执行的运算符,不会导致额外的运行时间开销。

13、【单选题】若有定义:int a=8,b=5,c; ,执行语句c=a/b+0.4;后,c的值为

A、1

B、1.4

C、2.0

D、2

14、【单选题】在C语言中,字符型数据在内存中以字符的( )形式存放

A、ASCII码

B、国标码

C、BCD码

D、反码

15、【单选题】以下符合C语言语法的实型常量是

A、5e-3

B、3.14.159e

C、1.2e0.5

D、e15

16、【单选题】以下选项中可作为C语言合法整数的是

A、0xffa

B、10110B

C、038x

D、x2a2

17、【单选题】下列说法正确的是

A、在C语言中,变量必须先定义后使用。

B、一条变量定义语句可定义多个同类型的变量。

C、C89规定所有变量必须在第一条可执行语句前定义。

D、const常量只能在定义时赋值。

E、实型常量的默认类型是double类型。

F、一条变量定义语句不可以同时定义多个变量。

G、不同类型的变量分配的存储空间大小都是相同的。

H、在C语言中,所有变量都必须在定义时进行初始化。

I、变量在没有初始化的时候,其值都是0

J、宏常量有数据类型,编译器在宏替换时可以进行类型检查。

18、【单选题】下列变量定义中合法的是

A、long ao=0xfdaL;

B、short _a=1-.1e-1;

C、double b=1+5e2.5;

D、float 2_and=1-e-3;

练兵区——单选题——不计入总分

1、【单选题】下列选项中,合法的C语言标识符是

A、_a1

B、width

C、

D、abc123

E、123abc

F、o*k

G、a?

H、a+b

I、%a

J、b!

2、【单选题】以下不适合定义为用户标识符的是

A、float

B、main

C、define

D、_3com_

E、PI

F、Source

G、abc

3、【单选题】#include stdio.h是

A、编译预处理指令

B、语句

C、函数

D、什么都不是

E、有语法错误

4、【单选题】在windows下,程序编译链接后形成的可执行文件是

A、.obj文件

B、.exe文件

C、.o文件

D、.c文件

E、.h文件

5、【单选题】程序编译链接后显示 0 error,0 warning 代表

A、程序中没有语法错误

B、程序是正确的

C、程序是不正确的

D、程序中可能存在语法错误

E、程序中有语义错误

6、【单选题】用8位无符号二进制数能表示的最大十进制数为

A、255

B、127

C、128

D、256

7、【单选题】关于可执行文件说法正确的是

A、可执行文件是编译链接后生成的文件

B、可执行文件就是源代码文件

C、可执行文件后缀为.obj

D、可执行文件就是main.c文件

8、【单选题】若变量a是int类型,并执行了语句:a='A'+1.6;,则正确的叙述是

A、'A'+1.6的结果是浮点型

B、a的值还是整型

C、a的值是字符C

D、a的值是浮点型

E、不允许字符型和浮点型相加

9、【单选题】C语言用sizeof计算变量在内存中的字节数,其中sizeof是()

A、运算符

B、一元运算符

C、只需要一个操作数的运算符

D、函数

E、语句

F、标识符

G、变量

10、【单选题】以下不属于Codeblocks中用于调试程序的工具是

A、run

B、build

C、run to cursor

D、next line

E、stop debugger

F、watches

11、【单选题】程序的开发步骤中不包括

A、撰写文档

B、运行程序

C、编译链接

D、程序测试

E、编辑(编写代码)

12、【单选题】下列说法中错误的是()

A、尾数决定了实数的表数范围,阶码决定了实数的表数精度。

B、内存是按位编址的。

C、有符号和无符号整数的表数范围是相同的。

D、int型在所有的计算机上都占4个字节的存储单元。

E、编译器按变量定义的类型对不同类型的变量分配不同大小的内存空间。

F、内存是按字节编址的。

G、对于同样的尾数,阶码的值越大,则浮点数所表示的数值的绝对值就越大。

H、sizeof是编译时执行的运算符,不会导致额外的运行时间开销。

13、【单选题】若有定义:int a=8,b=5,c; ,执行语句c=a/b+0.4;后,c的值为

A、1

B、1.4

C、2.0

D、2

14、【单选题】在C语言中,字符型数据在内存中以字符的( )形式存放

A、ASCII码

B、国标码

C、BCD码

D、反码

15、【单选题】以下符合C语言语法的实型常量是

A、5e-3

B、3.14.159e

C、1.2e0.5

D、e15

16、【单选题】以下选项中可作为C语言合法整数的是

A、0xffa

B、10110B

C、038x

D、x2a2

17、【单选题】下列说法正确的是

A、在C语言中,变量必须先定义后使用。

B、一条变量定义语句可定义多个同类型的变量。

C、C89规定所有变量必须在第一条可执行语句前定义。

D、const常量只能在定义时赋值。

E、实型常量的默认类型是double类型。

F、一条变量定义语句不可以同时定义多个变量。

G、不同类型的变量分配的存储空间大小都是相同的。

H、在C语言中,所有变量都必须在定义时进行初始化。

I、变量在没有初始化的时候,其值都是0

J、宏常量有数据类型,编译器在宏替换时可以进行类型检查。

18、【单选题】下列变量定义中合法的是

A、long ao=0xfdaL;

B、short _a=1-.1e-1;

C、double b=1+5e2.5;

D、float 2_and=1-e-3;

运算符的优先级和结合性

1、【判断题】二元的算术运算符的结合性都是左结合。

A、正确

B、错误

在定义变量的时候对变量进行初始化

1、【单选题】下列语句中错误的是()。

A、int a, b, c;a=b=c=0;

B、int a, b, c;a=0;b=0;c=0;

C、int a=0;int b=0;int c=0;

D、int a=b=c=0;

不同类型数据的运算

1、【判断题】通常情况下,不同类型数据的运算结果的类型是取值范围较大的那种类型。

A、正确

B、错误

强制类型转换

1、【判断题】强制类型转换运算符就是强制改变一个变量原有的数据类型。

A、正确

B、错误

练兵区——编程题——不计入总分

第2周测验

1、【单选题】下列程序的输出结果是#include stdio.h int main() { int a=7,b=5; printf(%d\n,b/a); return 0; }

A、0

B、5

C、1

D、0.7

2、【单选题】下列关于单目运算符++、--的叙述中正确的是

A、a++的运算过程是:先使用变量a的值,然后再执行a=a+1。

B、++a的运算过程是:先使用变量a的值,然后再执行a=a+1。

C、a++的运算过程是:先执行a=a+1,然后再使用变量a的值。

D、a++和++a都是最终使变量a执行a=a+1,因此对于包含a++或++a的表达式而言(如j=a++;或者j=++a;),两种情况下表达式的最终运算结果一定是相同的。

3、【单选题】以下程序的输出结果是:#include stdio.h int main() { int a=1, b=2; a=a+b; b=a-b; a=a-b; printf(%d,%d\n, a, b ); return 0; }

A、2,1

B、3,1

C、3,2

D、1,2

4、【单选题】程序运行后的输出结果是#include stdio.h int main() { int m=3,n=4,x; x=m++; ++n; x=x+8/n; printf(%d,%d\n,x,m); return 0; }

A、4,4

B、4,3

C、5,4

D、5,3

5、【单选题】下面程序的运行结果是#include stdio.h int main() { int a = 2, b = 3 ; float x = 3.5, y = 2.5 ; printf(%f, (float)(a+b) / 2 + (int)x % (int)y) ; return 0; }

A、3.500000

B、3.000000

C、3.5

D、3

6、【单选题】以下非法的赋值语句是

A、++(i+1);

B、x=(j--);

C、n=++i;

D、j++;

7、【单选题】设a和b均为double型变量,且a=5.5、b=2.5,则表达式(int)a+b/b的值是

A、6.000000

B、 6.500000

C、6

D、5.500000

8、【单选题】 以下程序的运行结果是#include stdio.h int main() { int a = 12, b = 3; float x = 18.5, y = 4.5; printf(%f\n, (float)(a * b) / 2); printf(%d\n, (int)x %(int)y); return 0; }

A、18.0000002

B、182

C、182.000000

D、18.0000002.000000

9、【单选题】设有语句“int a = 3;”,执行语句“a += a -= a * a;”后,变量a的值是

A、-12

B、3

C、0

D、9

10、【单选题】在C语言中,要求操作数必须是整型的运算符是

A、%

B、/

C、*

D、+

E、-

11、【单选题】程序运行后的输出结果是#include stdio.h int main() { char a='a'; printf(%c,,++a); printf(%c\n,a++); return 0; }

A、 b,b

B、b,c

C、a,b

D、a,c

12、【单选题】下面哪条语句可以生成0-9之间的随机数

A、magic=rand()%10;

B、magic=rand()%10+1;

C、magic=rand()/10;

D、magic=rand()/10+1;

13、【单选题】在下面的C语言语句中,存在错误的是

A、int a=b=10;

B、int a=10,b=10;

C、int a,b;a=b=10;

D、int a,b;a=10;b=10;

14、【单选题】若以下选项中的变量已正确定义,则正确的赋值语句是

A、x3=x2=x1=0;

B、x1=26.8%3;

C、1+2=x2;

D、x4=1+2=3;

15、【单选题】若有以下定义,则表达式“a * b + d – c”的值的类型为#include stdio.h int main() { char a; int b; float c; double d; .... return 0; }

A、double

B、int

C、float

D、char

16、【单选题】在C程序中如果要使用数学函数,如sin(x),log(x)等,需要在程序中加入的语句是

A、

B、include <math.h>

C、

D、include <stdio.h>

E、

F、define <math.h>

G、

H、define <stdio.h>

17、【单选题】十进制3位数整数x,下面哪条语句能正确分离出它的十位上的数字d?

A、d=(x-(x/100)*100)/10;

B、d=(x%100)/10;

C、d=(x/10)%10;

D、d=x%10;

E、d=(x-x%10)/10;

F、d=x%100;

18、【单选题】在C语言中对下面的语句而言,哪个说法是错误的?int a, b;

A、变量a和b中的值都是0

B、变量a和b中都没有数值

C、变量a和b中的值都是未知的随机数

D、a和b都是整型变量

E、变量a和b占用的内存空间的大小是相同的

19、【单选题】已知int a,b;并且有a=5%3;以及b=5/3;,则a和b的值分别是( )。

A、2和1

B、0和1.67

C、3和1

D、5和1

E、0和1

F、3和1.67

G、5和1.67

20、【单选题】设有以下定义,则下面给出的语句中错误的是int a=0; float b=1.25; char c='A'; #define d 2

A、d++;

B、(a+b)++;

C、(-a)++;

D、(a+1)++;

E、a++;

F、b++;

G、c++;

练兵区——单选题——不计入总分

1、【单选题】设有语句“int a = 3;”,执行语句“a += a -= a * a;”后,变量a的值是

A、-12

B、3

C、0

D、9

2、【单选题】在C程序中如果要使用数学函数,如sin(x),log(x)等,需要在程序中加入的语句是

A、

B、include <math.h>

C、

D、include <stdio.h>

E、

F、define <math.h>

G、

H、define <stdio.h>

3、【单选题】设有以下定义,则下面给出的语句中错误的是int a=0; float b=1.25; char c='A'; #define d 2

A、d++;

B、(a+b)++;

C、(-a)++;

D、(a+1)++;

E、a++;

F、b++;

G、c++;

4、【单选题】下列关于单目运算符++、--的叙述中正确的是

A、a++的运算过程是:先使用变量a的值,然后再执行a=a+1。

B、++a的运算过程是:先使用变量a的值,然后再执行a=a+1。

C、a++的运算过程是:先执行a=a+1,然后再使用变量a的值。

D、a++和++a都是最终使变量a执行a=a+1,因此对于包含a++或++a的表达式而言(如j=a++;或者j=++a;),两种情况下表达式的最终运算结果一定是相同的。

5、【单选题】以下程序的输出结果是:#include stdio.h int main() { int a=1, b=2; a=a+b; b=a-b; a=a-b; printf(%d,%d\n, a, b ); return 0; }

A、2,1

B、3,1

C、3,2

D、1,2

6、【单选题】下面哪条语句可以生成0-9之间的随机数

A、magic=rand()%10;

B、magic=rand()%10+1;

C、magic=rand()/10;

D、magic=rand()/10+1;

7、【单选题】在下面的C语言语句中,存在错误的是

A、int a=b=10;

B、int a=10,b=10;

C、int a,b;a=b=10;

D、int a,b;a=10;b=10;

8、【单选题】若有以下定义,则表达式“a * b + d – c”的值的类型为#include stdio.h int main() { char a; int b; float c; double d; .... return 0; }

A、double

B、int

C、float

D、char

9、【单选题】十进制3位数整数x,下面哪条语句能正确分离出它的十位上的数字d?

A、d=(x-(x/100)*100)/10;

B、d=(x%100)/10;

C、d=(x/10)%10;

D、d=x%10;

E、d=(x-x%10)/10;

F、d=x%100;

10、【单选题】在C语言中对下面的语句而言,哪个说法是错误的?int a, b;

A、变量a和b中的值都是0

B、变量a和b中都没有数值

C、变量a和b中的值都是未知的随机数

D、a和b都是整型变量

E、变量a和b占用的内存空间的大小是相同的

11、【单选题】下列程序的输出结果是#include stdio.h int main() { int a=7,b=5; printf(%d\n,b/a); return 0; }

A、0

B、5

C、1

D、0.7

12、【单选题】程序运行后的输出结果是#include stdio.h int main() { int m=3,n=4,x; x=m++; ++n; x=x+8/n; printf(%d,%d\n,x,m); return 0; }

A、4,4

B、4,3

C、5,4

D、5,3

13、【单选题】下面程序的运行结果是#include stdio.h int main() { int a = 2, b = 3 ; float x = 3.5, y = 2.5 ; printf(%f, (float)(a+b) / 2 + (int)x % (int)y) ; return 0; }

A、3.500000

B、3.000000

C、3.5

D、3

14、【单选题】以下非法的赋值语句是

A、++(i+1);

B、x=(j--);

C、n=++i;

D、j++;

15、【单选题】已知int a,b;并且有a=5%3;以及b=5/3;,则a和b的值分别是

A、2和1

B、0和1.67

C、3和1

D、5和1

E、0和1

F、3和1.67

G、5和1.67

16、【单选题】设a和b均为double型变量,且a=5.5、b=2.5,则表达式(int)a+b/b的值是

A、6.000000

B、 6.500000

C、6

D、5.500000

17、【单选题】以下程序的运行结果是#include stdio.h int main() { int a = 12, b = 3; float x = 18.5, y = 4.5; printf(%f\n, (float)(a * b) / 2); printf(%d\n, (int)x %(int)y); return 0; }

A、18.0000002

B、182

C、182.000000

D、18.0000002.000000

18、【单选题】在C语言中,要求操作数必须是整型的运算符是

A、%

B、/

C、*

D、+

E、-

19、【单选题】程序运行后的输出结果是#include stdio.h int main() { char a='a'; printf(%c,,++a); printf(%c\n,a++); return 0; }

A、b,b

B、b,c

C、a,b

D、a,c

20、【单选题】若以下选项中的变量已正确定义,则正确的赋值语句是

A、x3=x2=x1=0;

B、x1=26.8%3;

C、1+2=x2;

D、x4=1+2=3;

格式字符

1、【判断题】在调用printf函数输出数据时,当数据的实际位宽大于printf函数中的指定位宽时,将按照数据的实际位宽输出数据。

A、正确

B、错误

单个字符的输入输出

1、【判断题】单个字符既可以以c格式符也可以以d格式符输出,前者是输出这个字符,后者是输出这个字符的ASCII码值。

A、正确

B、错误

%c格式转换说明

1、【判断题】用c格式符输入字符型数据的时候,为了避免将输入缓冲区中的空白字符(空格、回车换行符、Tab键)作为有效字符读入,可以在%c前面加一个空格。

A、正确

B、错误

第3周编程题在线测试

练兵区——编程题——不计入总分

第3周测验

1、【单选题】分析下列程序,写出程序运行结果#include stdio.h int main() { char c1 = 'a', c2 = 'b', c3 = 'c'; printf(a%cb%cc%cabc\n, c1, c2, c3); return 0; }

A、aabbccabc

B、acbcabc

C、aabcabc

D、acbbcabc

2、【单选题】有如下语句,为使变量a的值为1,b的值为2,从键盘输入数据的正确形式是scanf(a=%d,b=%d,a,b);

A、a=1,b=2

B、1 2

C、1,2

D、a=1 b=2

3、【单选题】#include stdio.h int main() { int a,b,c,d; scanf(%c%c%d,%d,a,b,c,d); printf(%c,%c,%c,%c\n,a,b,c,d); return 0; }若运行以上程序时从键盘上输入:6565,66回车。则输出结果是

A、6,5,A,B

B、6,5,65,66

C、6,5,6,5

D、6,5,6,6

4、【单选题】给出程序的运行结果,程序运行时从键盘输入:54321回车#include stdio.h int main() { int a,b,s; scanf(%2d%2d,a,b); s=a/b; printf(s=%d,s); return 0; }

A、1

B、1.6875

C、2

D、0

5、【单选题】以下程序的输出结果为#include stdio.h int main() { float a = 1234.567,b = 55.32; printf(a = %4.2f, b = %5.1f\n, a,b); return 0; }

A、a = 1234.57, b = 55.3

B、a =1234, b =55

C、a = 1234.6, b = 5.32

D、a =1234.567, b = 55.32

6、【单选题】以下程序的输出结果为#include stdio.h int main() { int a=2, c=5; printf(a = %%d, b = %%d\n, a, c); return 0; }

A、a = %d, b = %d

B、a = %2, b = %5

C、a = 2, b = 5

D、a = %%d, b = %%d

7、【单选题】有以下程序,运行时若输入为B,则输出是#include stdio.h int main() { char ch; ch=getchar(); ch=ch+32; printf(%c,ch); return 0; }

A、b

B、98

C、32

D、66

8、【单选题】在调用printf函数输出数据时,当数据的实际位宽小于printf函数中的指定位宽时,下面叙述正确的是

A、如果格式字符前面没有负号,那么输出的数据将会右对齐、左补空格;如果格式字符前面有负号,那么输出的数据将会左对齐、右补空格。

B、如果格式字符前面没有负号,那么输出的数据将会左对齐、右补空格;如果格式字符前面有负号,那么输出的数据将会右对齐、左补空格。

C、如果格式字符前面没有负号,那么输出的数据将会右对齐、左补0;如果格式字符前面有负号,那么输出的数据将会左对齐、右补0。

D、如果格式字符前面没有负号,那么输出的数据将会左对齐、右补0;如果格式字符前面有负号,那么输出的数据将会右对齐、左补0。

9、【单选题】设有语句“char c='\72';”,则变量c

A、包含1个字符

B、包含2个字符

C、包含3个字符

D、不合法

10、【单选题】在下列语句中存在错误的是

A、int a,b;scanf("%d %f",&a,&b);

B、int a,b;scanf("%d %d",a,b);

C、int a,b;scanf("%d%d\n",&a,&b);printf("%d %d",a,b);

D、float a,b;scanf("%3.2f %4.2f",&a,&b);printf("%f %f",a,b);

E、float a,b;scanf("%f %f",&a,&b);printf("%f %f",a,b);

F、float a,b;scanf("%f %f",&a,&b);printf("a=%4.3f,b=%4.3f",a,b);

G、int a,b;scanf("%2d%2d",&a,&b);printf("a=%d,b=%d",a,b);

H、int a,b;scanf("%d,%d",&a,&b);printf("a=%2d,b=%2d",a,b);

I、int a,b;scanf("a=%d,b=%d",&a,&b);printf("a=%d,b=%d",a,b);

11、【单选题】程序运行后的输出结果是#include stdio.h int main() { int a=666,b=888; printf(%d\n,a,b); return 0; }

A、666

B、错误信息

C、888

D、666,888

12、【单选题】有以下语句段#include stdio.h int main() { int n1=10,n2=20; printf(_________,n1,n2); return 0; }要求按以下格式输出n1和n2的值,每个输出行都是从第一列开始,则空白处代码填写正确的是运行结果示例如下:n1=10n2=20

A、n1=%d\nn2=%d

B、n1=%dn2=%d\n

C、n1=%d,n2=%d

D、n1=%d n2=%d\n

13、【单选题】以下选项中合法的字符常量是

A、 '\010'

B、"B"

C、68

D、D

14、【单选题】写出下面程序的输出结果#includestdio.h int main() { int x=6,y,z; x*=18+1; printf(%d,,x--); x+=y=z=11; printf(%d,x); return 0; }

A、114,124

B、113,124

C、109,116

D、110,116

15、【单选题】给出程序的运行结果,程序运行时从键盘输入:45-12回车#include stdio.h int main() { int a,b,sum; scanf(%d%*c%d,a,b); sum=a+b; printf(sum=%d,sum); return 0; }

A、57

B、输出报错

C、33

D、输出一个随机数

16、【单选题】给出程序的运行结果#include stdio.h int main() { int a,b,s; char op; scanf(%d %c%d,a,op,b); s=a%b; printf(s=%d,s); return 0; }程序运行时从键盘输入:15回车%5回车

A、0

B、程序报错

C、输出一个随机数

D、3

17、【单选题】给出程序的运行结果#include stdio.h int main() { int a,b,c,d; char op1,op2,op3; int sum; printf(please input:a+b+c+d\n); scanf(%d%c%d%c%d%c%d,a,op1,b,op2,c,op3,d); sum=a+b+c+d; printf(sum=%d,sum); return 0; }程序运行时从键盘输入:1回车2+3+1回车

A、7

B、1

C、3

D、6

18、【单选题】在C语言中,字符型数据在内存中以( )形式存放

A、ASCII码

B、国标码

C、BCD码

D、反码

19、【单选题】以下程序的执行结果是#include stdio.h int main() { int a = 5, b = 4, x, y; x = 2 * a++; y = --b * 2; printf(a=%d, x=%d\n, a, x); printf(b=%d, y=%d\n, b, y); return 0; }

A、a=6, x=10b=3, y=6

B、a=6, x=10b=3, y=8

C、a=6, x=12b=3, y=6

D、以上均不对

20、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a; int c=10; float f=100.0; double x; a=f/=c*=(x=6.5); printf(%d,%d,%3.1f,%3.1f\n,a,c,f,x); return 0; }

A、1,65,1.5,6.5

B、1,65,1,6.5

C、1,65,1.0,6.5

D、 2,65,1.5,6.5

21、【单选题】给出程序的运行结果#include stdio.h int main() { char a,b; int s; printf(please input a and b:\n); a=getchar(); b=getchar(); s=a+b; printf(a=%c,b=%c,a,b); return 0; }程序运行时从键盘输入:1空格2回车

A、a=1,b=

B、a=1,b=2

C、a= ,b=2

D、输出乱码

22、【单选题】以下程序的输出结果是#include stdio.h int main() { int a=1234; printf(%2d\n,a); return 0; }

A、1234

B、12

C、34

D、提示出错、无结果

练兵区——单选题——不计入总分

1、【单选题】以下程序的输出结果为#include stdio.h int main() { float a = 1234.567,b = 55.32; printf(a = %4.2f, b = %5.1f\n, a,b); return 0; }

A、a = 1234.57, b = 55.3

B、a =1234, b =55

C、a = 1234.6, b = 5.32

D、a =1234.567, b = 55.32

2、【单选题】以下选项中合法的字符常量是

A、 '\010'

B、"B"

C、68

D、D

3、【单选题】给出程序的运行结果程序运行时从键盘输入:1空格2回车#include stdio.h int main() { char a,b; int s; printf(please input a and b:\n); a=getchar(); b=getchar(); s=a+b; printf(a=%c,b=%c,a,b); return 0; }

A、a=1,b=

B、a=1,b=2

C、a= ,b=2

D、输出乱码

4、【单选题】有如下语句,为使变量a的值为1,b的值为2,从键盘输入数据的正确形式是scanf(a=%d,b=%d,a,b)

A、a=1,b=2

B、1 2

C、1,2

D、a=1 b=2

5、【单选题】#include stdio.h int main() { int a,b,c,d; scanf(%c%c%d,%d,a,b,c,d); printf(%c,%c,%c,%c\n,a,b,c,d); return 0; }若运行以上程序时从键盘上输入:6565,66回车。则输出结果是

A、6,5,A,B

B、6,5,65,66

C、6,5,6,5

D、6,5,6,6

6、【单选题】给出程序的运行结果,程序运行时从键盘输入:54321回车#include stdio.h int main() { int a,b,s; scanf(%2d%2d,a,b); s=a/b; printf(s=%d,s); return 0; }

A、1

B、1.6875

C、2

D、0

7、【单选题】在调用printf函数输出数据时,当数据的实际位宽小于printf函数中的指定位宽时,下面叙述正确的是

A、如果格式字符前面没有负号,那么输出的数据将会右对齐、左补空格;如果格式字符前面有负号,那么输出的数据将会左对齐、右补空格。

B、如果格式字符前面没有负号,那么输出的数据将会左对齐、右补空格;如果格式字符前面有负号,那么输出的数据将会右对齐、左补空格。

C、如果格式字符前面没有负号,那么输出的数据将会右对齐、左补0;如果格式字符前面有负号,那么输出的数据将会左对齐、右补0。

D、如果格式字符前面没有负号,那么输出的数据将会左对齐、右补0;如果格式字符前面有负号,那么输出的数据将会右对齐、左补0。

8、【单选题】程序运行后的输出结果是#include stdio.h int main() { int a=666,b=888; printf(%d\n,a,b); return 0; }

A、666

B、错误信息

C、888

D、666,888

9、【单选题】在C语言中,字符型数据在内存中以( )形式存放

A、ASCII码

B、国标码

C、BCD码

D、反码

10、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a; int c=10; float f=100.0; double x; a=f/=c*=(x=6.5); printf(%d,%d,%3.1f,%3.1f\n,a,c,f,x); return 0; }

A、1,65,1.5,6.5

B、1,65,1,6.5

C、1,65,1.0,6.5

D、 2,65,1.5,6.5

11、【单选题】以下程序的输出结果是#include stdio.h int main() { int a=1234; printf(%2d\n,a); return 0; }

A、1234

B、12

C、34

D、提示出错、无结果

12、【单选题】设有语句“char c='\72';”,则变量c

A、包含1个字符

B、包含2个字符

C、包含3个字符

D、不合法

13、【单选题】有以下语句段#include stdio.h int main() { int n1=10,n2=20; printf(_________,n1,n2); return 0; }要求按以下格式输出n1和n2的值,每个输出行都是从第一列开始,则空白处代码填写正确的是运行结果示例如下:n1=10n2=20

A、n1=%d\nn2=%d

B、n1=%dn2=%d\n

C、n1=%d,n2=%d

D、n1=%d n2=%d\n

14、【单选题】给出程序的运行结果,程序运行时从键盘输入:45-12回车#include stdio.h int main() { int a,b,sum; scanf(%d%*c%d,a,b); sum=a+b; printf(sum=%d,sum); return 0; }

A、57

B、输出报错

C、33

D、输出一个随机数

15、【单选题】给出程序的运行结果#include stdio.h int main() { int a,b,s; char op; scanf(%d %c%d,a,op,b); s=a%b; printf(s=%d,s); return 0; }程序运行时从键盘输入:15回车%5回车

A、0

B、程序报错

C、输出一个随机数

D、3

16、【单选题】分析下列程序,写出程序运行结果#include stdio.h int main() { char c1 = 'a', c2 = 'b', c3 = 'c'; printf(a%cb%cc%cabc\n, c1, c2, c3); return 0; }

A、aabbccabc

B、acbcabc

C、aabcabc

D、acbbcabc

17、【单选题】以下程序的输出结果为#include stdio.h int main() { int a=2, c=5; printf(a = %%d, b = %%d\n, a, c); return 0; }

A、a = %d, b = %d

B、a = %2, b = %5

C、a = 2, b = 5

D、a = %%d, b = %%d

18、【单选题】有以下程序,运行时若输入为B,则输出是#include stdio.h int main() { char ch; ch=getchar(); ch=ch+32; printf(%c,ch); return 0; }

A、b

B、98

C、32

D、66

19、【单选题】在下列语句中存在错误的是

A、int a,b;scanf("%d %f",&a,&b);

B、int a,b;scanf("%d %d",a,b);

C、int a,b;scanf("%d%d\n",&a,&b);printf("%d %d",a,b);

D、float a,b;scanf("%3.2f %4.2f",&a,&b);printf("%f %f",a,b);

E、float a,b;scanf("%f %f",&a,&b);printf("%f %f",a,b);

F、float a,b;scanf("%f %f",&a,&b);printf("a=%4.3f,b=%4.3f",a,b);

G、int a,b;scanf("%2d%2d",&a,&b);printf("a=%d,b=%d",a,b);

H、int a,b;scanf("%d,%d",&a,&b);printf("a=%2d,b=%2d",a,b);

I、int a,b;scanf("a=%d,b=%d",&a,&b);printf("a=%d,b=%d",a,b);

20、【单选题】写出下面程序的输出结果#includestdio.h int main() { int x=6,y,z; x*=18+1; printf(%d,,x--); x+=y=z=11; printf(%d,x); return 0; }

A、114,124

B、113,124

C、109,116

D、110,116

21、【单选题】给出程序的运行结果#include stdio.h int main() { int a,b,c,d; char op1,op2,op3; int sum; printf(please input:a+b+c+d\n); scanf(%d%c%d%c%d%c%d,a,op1,b,op2,c,op3,d); sum=a+b+c+d; printf(sum=%d,sum); return 0; }程序运行时从键盘输入:1回车2+3+1回车

A、7

B、1

C、3

D、6

22、【单选题】以下程序的执行结果是#include stdio.h int main() { int a = 5, b = 4, x, y; x = 2 * a++; y = --b * 2; printf(a=%d, x=%d\n, a, x); printf(b=%d, y=%d\n, b, y); return 0; }

A、a=6, x=10b=3, y=6

B、a=6, x=10b=3, y=8

C、a=6, x=12b=3, y=6

D、以上均不对

判断ch是英文字母(大写或者小写)

1、【判断题】下面判断ch是大写或者小写英文字母的表达式是否正确?ch = 'A' ch = 'Z' || ch = 'a' ch = 'z'

A、正确

B、错误

条件运算符

1、【单选题】下列关于if-else语句的说法中哪个是正确的。

A、else总是和离它最近的if配对

B、else总是和前面离它最近的且还未和其他else匹配的在同一语句块内同一层次的if配对

C、else总是和前面离它最近的且位于花括号内的if配对

D、else可以和它前面的尚未与其他else匹配的任何一个if配对

2、【判断题】条件运算符是C语言中唯一的一个三元运算符.

A、正确

B、错误

赋值中的自动类型转换

1、【单选题】在赋值操作中,当赋值表达式左侧的变量的类型与右侧的表达式的类型不一致的时候,下面说法正确的是()。

A、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,会发生自动类型转换,赋值表达式的结果类型是赋值运算符左侧变量的类型。

B、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,赋值表达式的结果类型是赋值运算符右侧表达式的类型。

C、在赋值操作中,只要赋值运算符左侧的变量的类型与右侧的表达式的类型不一致,就会发生数值溢出。

D、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,要么发生数值溢出,要么发生数值精度的损失。

浮点数的表数精度

1、【单选题】下列说法错误的是()。

A、浮点数并非真正意义上的实数,只是其在某种范围内的近似。

B、浮点数能精确表示的数字位数取决于这种类型的浮点数的有效数字位数。

C、使用更多的位来存储阶码,将会扩大浮点数的表数精度。

D、受浮点数表数精度的限制,因此对于浮点数不能直接比较其是否相等,应该比较其是否近似相等。

程序测试

1、【单选题】下列说法错误的是()。

A、软件测试的目的就是证明程序的正确性,即给定特定的输入,通过运行被测程序,检查程序的输出是否与预期结果一致,进而验证程序的正确性。

B、白盒测试就是在完全了解程序的结构和处理过程的情况下,按照程序内部的逻辑测试程序,检验程序中的每条逻辑路径是否都能按预定要求正确工作。黑盒测试就是把系统看成一个黑盒子,不考虑程序内部的逻辑结构和处理过程,只根据需求规格说明书的要求,设计测试用例,检查程序的功能是否符合它的功能说明。

C、在选择测试用例时,不仅要选取合理的输入数据,还要选取一些不合理的输入数据,以及某些极端的边界点或临界点等,对程序进行测试

D、由于修复了旧的bug的同时,往往又会产生新的bug,因此往往还需要对所有出现过的bug重新测试一遍,看其是否会重新出现,并给确认代码修改后没有引入新的bug,即修改代码后需要进行回归测试。

第4周编程题在线测试

练兵区——编程题——不计入总分

第4周测验

1、【单选题】程序代码如下:#include stdio.h int main() { int a,b; printf(please input a and b:\n); scanf(%d%d,a,b); printf(the output data is %d\n,ab?b:a); return 0; }从键盘输入以下数据:2回车7回车则程序输出为

A、the output data is 7

B、the output data is 2

C、the output data is 1

D、the output data is 0

2、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a,b,c; a=10; b=20; c=(a%b1)||(a/b1); printf(%d,%d,%d,a%b,a/b,c); return 0; }

A、10,0,0

B、10,1,0

C、10,0,1

D、10,1,1

3、【单选题】从键盘输入三角形的三边长为a,b,c,按下面公式计算并输出三角形的面积。程序代码如下,但程序运行后输出结果不正确,请找出有问题的语句。#include stdio.h #include math.h int main() { float a, b, c; float s, area; printf(Input a,b,c:); scanf(%f,%f,%f,a,b,c); if (a+bc b+ca a+cb) { s = 1/2 * (a + b + c); area = sqrt(s * (s - a) * (s - b) * (s - c)); printf(area=%.2f\n, area); } else { printf(It is not a triangle\n); } return 0; }

A、第11行: s = 1/2 * (a + b + c);

B、第9行: if (a+b>c && b+c>a && a+c>b)

C、第12行: area = sqrt(s * (s - a) * (s - b) * (s - c));

D、第8行: scanf("%f,%f,%f",&a,&b,&c);

4、【单选题】编程设计一个简单的计算器程序,要求用户从键盘输入如下形式的表达式: 操作数1 运算符op 操作数2然后,计算并输出表达式的值指定的运算符为: 加(+) 减(-) 乘(*) 除(/)代码如下,所给程序是否存在错误,若有,找出错误所在并改正。#include stdio.h int main() { float data1, data2; char op; printf(Please enter the expression:); scanf(%f %c%f, data1, op, data2); /* %c前有一个空格 */ switch (op) { case '+': printf(%f + %f = %f\n, data1, data2, data1 + data2); break; case '-': printf(%f - %f = %f\n, data1, data2, data1 - data2); break; case '*': printf(%f * %f = %f\n, data1, data2, data1 * data2); break; case '/': printf(%f/%f = %f\n, data1, data2,data1/data2); break; default: printf(Invalid operator!\n); } return 0; }

A、第20行语句有错误,改成:if (fabs(data2)<=EPS) printf("Division by zero!\n");else printf("%f/%f = %f\n", data1, data2, data1/data2);同时,第1行语句下方应加入

B、include <math.h>

C、define EPS 1e-6

D、default分支缺少break语句

E、没有错误

F、第20行语句有错误,改成:if (data2=0) printf("Division by zero!\n");else printf("%f/%f = %f\n", data1, data2, data1/data2);

5、【单选题】若x和y代表整型数,以下表达式中不能正确表示数学关系|x-y|10的是

A、(x-y)<-10||!(y-x)>10

B、 fabs(x-y)<10

C、x-y>-10 && x-y<10

D、(x-y)*(x-y)<100

6、【单选题】下列复合语句中,不能实现两数交换的是

A、{ a=b; b=a; }

B、{ b = a * b; a = b / a; b = b / a; }

C、{ t=a; a=b; b=t; }

D、{ a = a + b; b = a – b; a = a – b; }

7、【单选题】写出下面程序的输出结果#include stdio.h int main() { int x=1, y=0, a=0, b=0; switch(x) { case 1: switch(y) { case 0: a++; case 1: b++; } case 2: a++; b++; } printf(a=%d, b=%d\n, a, b) ; return 0; }

A、a=2, b=2

B、a=2, b=1

C、a=1, b=1

D、a=1, b=0

8、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a=5,b=4,c=3,d; d=(abc); printf(%d\n,d); return 0; }

A、0

B、1

C、5

D、4

E、3

9、【单选题】执行以下程序后的输出结果为#include stdio.h int main() { int a=1,b=0; switch (a) { case 1: switch (b) { case 0: printf(**0**);break; case 1: printf(**1**);break; } case 2: printf(**2**);break; } return 0; }

A、**0****2**

B、**0**

C、**0****1****2**

D、有语法错误

10、【单选题】下面程序运行后的输出结果是#include stdio.h int main() { int a=3,b=4,c=5,d=2; if(ab) { if(bc) { printf(%d,d++ +1); } else { printf(%d,++d +1); } } printf(%d\n,d); return 0; }

A、2

B、3

C、43

D、44

11、【单选题】下面程序代码的功能是判断输入整数的正负性和奇偶性,请将第19行和22行标号处缺少的代码填写完整。#include stdio.h int main() { int m; printf(Input m: ); scanf(%d, m); //输入一个整数 if (m 0) //是否为正数 { if (m % 2 == 0) //是正数,且能被2整除,则是正偶数 { printf(%d is a positive even\n, m); } else //不能被2整除,则是正奇数 { printf(%d is a positive odd\n, m); } } _______________ //判断是否为负数 { _______________ { printf(%d is a negative even\n, m); //是负偶数 } else { printf(%d is a negative odd\n, m); //是负奇数 } } else { printf(%d is zero.It is an even\n, m); } return 0; }

A、第19行代码: else if(m < 0)第22行代码: if (m % 2 == 0)

B、第19行代码: if(m < 0)第22行代码: if (m % 2 == 0)

C、第19行代码: else if(m < 0)第22行代码: if (m % 2 != 0)

D、第19行代码: if(m < 0)第22行代码: if (m % 2 != 0)

12、【单选题】程序功能:从键盘输入一个字符,判别它是否为大写字母。如果是,将它转换成小写字母,如果不是,不转换。在屏幕上输出最后得到的字符。程序代码如下,为实现上述功能,请将第8行标号处缺少的语句填写完整。#includestdio.h int main() { char c; printf(Please input a character:); scanf(%c,c); if(c ='A'c = 'Z') c =_______________; printf(%c\n,c); return 0; }

A、c+32

B、c+48

C、C+65

D、C+97

13、【单选题】执行下列程序,k输入为1时的输出结果是#include stdio.h int main() { int k; scanf(%d,k); switch(k) { case 1: printf(%d,k++); case 2: printf(%d,k++); case 3: printf(%d,k++); break; default: printf(Full!); } return 0; }

A、123

B、1

C、2

D、3

14、【单选题】编程计算下面的分段函数,根据从键盘输入的x值,在屏幕上输出y值。 程序代码如下,为完成以上功能,请将第13行标号处缺少的代码填写完整。 #include stdio.h #include math.h int main() { int x; double y; printf(Input x: ); scanf(%d, x); // 输入一个整数 if (x 0) { y = exp(-x); //如果大于0,计算y=exp(-x)的值 } _____________ { y = 1; //x=0,则y=1 } else { y = -exp(x); //x0,则y=-exp(x) } printf(y=%f\n, y); return 0; }

A、else if (x == 0)

B、else if (x = 0)

C、if (x == 0)

D、if (x = 0)

15、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a=1,b=2,m=0,n=0,k; k=(n=ba)||(m=ab); printf(%d,%d\n,k,m); return 0; }

A、1,0

B、0,0

C、0,1

D、1,1

16、【单选题】以下程序的功能是计算一元二次方程的根。代码如下,请将第10行标号处缺少的语句填写完整。 #include stdio.h #include stdlib.h #include math.h #define EPS 1e-6 int main() { float a, b, c, disc, p, q; printf(Please enter the coefficients a,b,c:); scanf(%f,%f,%f, a, b, c); _________________________________ /* a=0时,输出不是二次方程 */ { printf(It is not a quadratic equation!\n); exit(0); /* C标准库函数,用于终止整个程序的执行,强制返回操作系统 */ } disc = b * b - 4 * a * c; /* 计算判别式 */ p = - b / (2 * a); q = sqrt(fabs(disc)) / (2 * a); if (fabs(disc) = EPS) /* 判别式等于0时,输出两相等实根 */ { printf(x1 = x2 = %.2f\n, p); } else { if (disc EPS) /* 判别式大于0时,输出两不等实根 */ { printf(x1 = %.2f, x2 = %.2f\n, p+q, p-q); } else /* 判别式小于0时,输出两共轭复根 */ { printf(x1 = %.2f+%.2fi, , p, q); printf(x2 = %.2f-%.2fi\n, p, q); } } return 0; }

A、if (fabs(a) <= EPS)

B、if (a <= EPS)

C、if (a=0)

D、if (a<= EPS || a>=-EPS)

17、【单选题】下列说法错误的是()。

A、case后的“常量表达式”的类型只能是整型。

B、若case后面的语句省略不写,则表示它什么也不做。

C、switch语句中的break和default可有可无。

D、每个case后的“常量表达式”的类型应该与switch后括号内表达式的类型一致。

E、程序执行到switch语句时,先计算表达式的值,然后自上而下寻找与该值匹配的case常量,找到后则按顺序执行此case后的所有语句,而不再进行判断,直到遇break语句或右花括号}为止。

F、若所有的case常量都不能与表达式的值相匹配,那么就执行default后面的语句。通常用于处理不在合理区间内的非法数据。

G、每个case后的常量只起语句标号的作用,所以case常量的值必须互不相同,而且在每个case的语句序列后都有break的情况下,改变case常量出现的次序,不影响程序的运行结果。

H、case后面的表达式不能是含有变量的关系表达式和逻辑表达式,它不能像if语句那样起到判断表达式真假的作用。

练兵区——单选题——不计入总分

1、【单选题】下面程序代码的功能是判断输入整数的正负性和奇偶性,请将第19行和22行标号处缺少的代码填写完整。#include stdio.h int main() { int m; printf(Input m: ); scanf(%d, m); //输入一个整数 if (m 0) //是否为正数 { if (m % 2 == 0) //是正数,且能被2整除,则是正偶数 { printf(%d is a positive even\n, m); } else //不能被2整除,则是正奇数 { printf(%d is a positive odd\n, m); } } _______________ //判断是否为负数 { _______________ { printf(%d is a negative even\n, m); //是负偶数 } else { printf(%d is a negative odd\n, m); //是负奇数 } } else { printf(%d is zero.It is an even\n, m); } return 0; }

A、第19行代码: else if(m < 0)第22行代码: if (m % 2 == 0)

B、第19行代码: if(m < 0)第22行代码: if (m % 2 == 0)

C、第19行代码: else if(m < 0)第22行代码: if (m % 2 != 0)

D、第19行代码: if(m < 0)第22行代码: if (m % 2 != 0)

2、【单选题】执行以下程序后的输出结果为#include stdio.h int main() { int a=1,b=0; switch (a) { case 1: switch (b) { case 0: printf(**0**);break; case 1: printf(**1**);break; } case 2: printf(**2**);break; } return 0; }

A、**0****2**

B、**0**

C、**0****1****2**

D、有语法错误

3、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a=1,b=2,m=0,n=0,k; k=(n=ba)||(m=ab); printf(%d,%d\n,k,m); return 0; }

A、1,0

B、0,0

C、0,1

D、1,1

4、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a,b,c; a=10; b=20; c=(a%b1)||(a/b1); printf(%d,%d,%d,a%b,a/b,c); return 0; }

A、10,0,0

B、10,1,0

C、10,0,1

D、10,1,1

5、【单选题】编程设计一个简单的计算器程序,要求用户从键盘输入如下形式的表达式: 操作数1 运算符op 操作数2然后,计算并输出表达式的值指定的运算符为: 加(+) 减(-) 乘(*) 除(/)代码如下,所给程序是否存在错误,若有,找出错误所在并改正。#include stdio.h int main() { float data1, data2; char op; printf(Please enter the expression:); scanf(%f %c%f, data1, op, data2); /* %c前有一个空格 */ switch (op) { case '+': printf(%f + %f = %f\n, data1, data2, data1 + data2); break; case '-': printf(%f - %f = %f\n, data1, data2, data1 - data2); break; case '*': printf(%f * %f = %f\n, data1, data2, data1 * data2); break; case '/': printf(%f/%f = %f\n, data1, data2,data1/data2); break; default: printf(Invalid operator!\n); } return 0; }

A、第20行语句有错误,改成:if (fabs(data2)<=EPS) printf("Division by zero!\n");else printf("%f/%f = %f\n", data1, data2, data1/data2);同时,第1行语句下方应加入

B、include <math.h>

C、define EPS 1e-6

D、default分支缺少break语句

E、没有错误

F、第20行语句有错误,改成:if (data2=0) printf("Division by zero!\n");else printf("%f/%f = %f\n", data1, data2, data1/data2);

6、【单选题】下列复合语句中,不能实现两数交换的是

A、{ a=b; b=a; }

B、{ b = a * b; a = b / a; b = b / a; }

C、{ t=a; a=b; b=t; }

D、{ a = a + b; b = a – b; a = a – b; }

7、【单选题】写出下面程序的输出结果#include stdio.h int main() { int x=1, y=0, a=0, b=0; switch(x) { case 1: switch(y) { case 0: a++; case 1: b++; } case 2: a++; b++; } printf(a=%d, b=%d\n, a, b) ; return 0; }

A、a=2, b=2

B、a=2, b=1

C、a=1, b=1

D、a=1, b=0

8、【单选题】执行下列程序,k输入为1时的输出结果是#include stdio.h int main() { int k; scanf(%d,k); switch(k) { case 1: printf(%d,k++); case 2: printf(%d,k++); case 3: printf(%d,k++); break; default: printf(Full!); } return 0; }

A、123

B、1

C、2

D、3

9、【单选题】编程计算下面的分段函数,根据从键盘输入的x值,在屏幕上输出y值。程序代码如下,为完成以上功能,请将第13行标号处缺少的代码填写完整。#include stdio.h #include math.h int main() { int x; double y; printf(Input x: ); scanf(%d, x); // 输入一个整数 if (x 0) { y = exp(-x); //如果大于0,计算y=exp(-x)的值 } _____________ { y = 1; //x=0,则y=1 } else { y = -exp(x); //x0,则y=-exp(x) } printf(y=%f\n, y); return 0; }

A、else if (x == 0)

B、else if (x = 0)

C、if (x == 0)

D、if (x = 0)

10、【单选题】以下程序的功能是计算一元二次方程的根。代码如下,请将第10行标号处缺少的语句填写完整。#include stdio.h #include stdlib.h #include math.h #define EPS 1e-6 int main() { float a, b, c, disc, p, q; printf(Please enter the coefficients a,b,c:); scanf(%f,%f,%f, a, b, c); _________________________________ /* a=0时,输出不是二次方程 */ { printf(It is not a quadratic equation!\n); exit(0); /* C标准库函数,用于终止整个程序的执行,强制返回操作系统 */ } disc = b * b - 4 * a * c; /* 计算判别式 */ p = - b / (2 * a); q = sqrt(fabs(disc)) / (2 * a); if (fabs(disc) = EPS) /* 判别式等于0时,输出两相等实根 */ { printf(x1 = x2 = %.2f\n, p); } else { if (disc EPS) /* 判别式大于0时,输出两不等实根 */ { printf(x1 = %.2f, x2 = %.2f\n, p+q, p-q); } else /* 判别式小于0时,输出两共轭复根 */ { printf(x1 = %.2f+%.2fi, , p, q); printf(x2 = %.2f-%.2fi\n, p, q); } } return 0; }

A、if (fabs(a) <= EPS)

B、if (a <= EPS)

C、if (a=0)

D、if (a<= EPS || a>=-EPS)

11、【单选题】从键盘输入三角形的三边长为a,b,c,按下面公式计算并输出三角形的面积。程序代码如下,但程序运行后输出结果不正确,请找出有问题的语句。#include stdio.h #include math.h int main() { float a, b, c; float s, area; printf(Input a,b,c:); scanf(%f,%f,%f,a,b,c); if (a+bc b+ca a+cb) { s = 1/2 * (a + b + c); area = sqrt(s * (s - a) * (s - b) * (s - c)); printf(area=%.2f\n, area); } else { printf(It is not a triangle\n); } return 0; }

A、第11行: s = 1/2 * (a + b + c);

B、第9行: if (a+b>c && b+c>a && a+c>b)

C、第12行: area = sqrt(s * (s - a) * (s - b) * (s - c));

D、第8行: scanf("%f,%f,%f",&a,&b,&c);

12、【单选题】若x和y代表整型数,以下表达式中不能正确表示数学关系|x-y|10的是

A、(x-y)<-10||!(y-x)>10

B、 fabs(x-y)<10

C、x-y>-10 && x-y<10

D、(x-y)*(x-y)<100

13、【单选题】程序功能:从键盘输入一个字符,判别它是否为大写字母。如果是,将它转换成小写字母,如果不是,不转换。在屏幕上输出最后得到的字符。程序代码如下,为实现上述功能,请将第8行标号处缺少的语句填写完整。#includestdio.h int main() { char c; printf(Please input a character:); scanf(%c,c); if(c ='A'c = 'Z') c =_______________; printf(%c\n,c); return 0; }

A、c+32

B、c+48

C、c+65

D、c+97

14、【单选题】程序代码如下:#include stdio.h int main() { int a,b; printf(please input a and b:\n); scanf(%d%d,a,b); printf(the output data is %d\n,ab?b:a); return 0; }从键盘输入以下数据:2回车7回车则程序输出为

A、the output data is 7

B、the output data is 2

C、the output data is 1

D、the output data is 0

15、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a=5,b=4,c=3,d; d=(abc); printf(%d\n,d); return 0; }

A、0

B、1

C、5

D、4

E、3

16、【单选题】下面程序运行后的输出结果是#include stdio.h int main() { int a=3,b=4,c=5,d=2; if(ab) { if(bc) { printf(%d,d++ +1); } else { printf(%d,++d +1); } } printf(%d\n,d); return 0; }

A、2

B、3

C、43

D、44

17、【单选题】下列说法错误的是()。

A、case后的“常量表达式”的类型只能是整型。

B、若case后面的语句省略不写,则表示它什么也不做。

C、switch语句中的break和default可有可无。

D、每个case后的“常量表达式”的类型应该与switch后括号内表达式的类型一致。

E、程序执行到switch语句时,先计算表达式的值,然后自上而下寻找与该值匹配的case常量,找到后则按顺序执行此case后的所有语句,而不再进行判断,直到遇break语句或右花括号}为止。

F、若所有的case常量都不能与表达式的值相匹配,那么就执行default后面的语句。通常用于处理不在合理区间内的非法数据。

G、每个case后的常量只起语句标号的作用,所以case常量的值必须互不相同,而且在每个case的语句序列后都有break的情况下,改变case常量出现的次序,不影响程序的运行结果。

H、case后面的表达式不能是含有变量的关系表达式和逻辑表达式,它不能像if语句那样起到判断表达式真假的作用。

逗号运算符

1、【单选题】下列说法错误的是()。

A、逗号运算符也称为顺序求值运算符,由逗号运算符构成的表达式称为逗号表达式。

B、多数情况下,我们并不使用整个逗号表达式的值,主要用它来顺序求得到各个子表达式的值。

C、逗号表达式主要用在循环语句中同时对多个变量赋初值等。

D、在逗号表达式中,其第一个表达式的值就是整个逗号表达式的值。

随机数的生成

1、【单选题】下列说法错误的是()。

A、函数rand()用于生成一个[0,RAND_MAX]间的随机数,RAND_MAX是不大于双字节整数的最大值32767的宏常量。使用函数rand()必须在程序开头加上这样一条编译预处理指令:

B、include <stdio.h>

C、magic = rand()%100 + 1用于生成[1,100]之间的随机数。

D、事实上,函数rand()产生的都是伪随机数。

E、函数srand()用于为rand()设置随机数种子,使rand()产生的随机数“随机化”。

嵌套循环

1、【单选题】下列说法错误的是( )。

A、执行嵌套循环时是先执行内层循环,后执行外层循环。

B、嵌套循环的内层和外层循环的循环控制变量不能同名。

C、嵌套循环的循环次数等于外层循环的循环次数与内层循环的循环次数之积。

D、如果一个循环的循环体中又完整地包含了另一个循环,则称为嵌套循环。

流程的转移控制

1、【单选题】下面程序段中的break语句是转移到哪里去执行()。for(...) { for(...) { switch(...) { case 1: ... break; case 2:... ... } A: //code } B: //code } C: //code

A、转到标号A所在的语句行与执行

B、转到标号B所在的语句行与执行

C、转到标号C所在的语句行与执行

D、不进行流程转移,而是继续执行break后面的语句

程序调试

1、【单选题】下列说法错误的是()。

A、程序测试的目的就是验证程序的正确性。

B、程序中常见的错误有三种:编译错误,链接错误,以及运行时错误。

C、编译错误通常是由语法错误造成的。

D、运行时错误是指在程序运行时发生的错误,运行时错误有两种:一种是导致程序的运行结果与预期的不一致,另一种是导致程序无法正常运行。

第5周编程题在线测试

练兵区——编程题——不计入总分

第5周测验

1、【单选题】程序运行后的输出结果是#include stdio.h int main() { int i; for(i=0;i3;i++) switch(i) { case 0: printf(%d,i); case 2: printf(%d,i); default: printf(%d,i); } return 0; }

A、000122

B、022111

C、021021

D、012

2、【单选题】若变量已正确定义,要求程序段完成求5!的计算,不能完成此操作的程序段是

A、for( i=1; i<=5; i++ ) { p=1; p*=i; }

B、for(i=1,p=1;i<=5;i++) p*=i;

C、i=1; p=1; while ( i<=5 ) { p*=i; i++; }

D、i=1; p=1; do { p*=i; i++; } while ( i<=5 );

3、【单选题】以下程序执行后的输出结果是#include stdio.h int main( ) { int x=0,y=5,z=3; while(z--0 ++x5) { y=y-1; } printf(%d,%d,%d\n,x,y,z); return 0; }

A、3,2,-1

B、3,2,0

C、4,3,-1

D、5,-2,-5

4、【单选题】下面程序的输出是#include stdio.h int main() { int y=9; for( ; y0; y--) { if(y%3==0) { printf(%d, --y); continue; } } return 0; }

A、852

B、741

C、963

D、875421

5、【单选题】爱因斯坦数学题。爱因斯坦曾出过这样一道数学题:有一条长阶梯,若每步跨2阶,最后剩下1阶;若每步跨3阶,最后剩下2阶;若每步跨5阶,最后剩下4阶;若每步跨6阶,最后剩下5阶;只有每步跨7阶,最后才正好1阶不剩。请问,这条阶梯共有多少阶?代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int x = 1, find = 0; while (__________) { if (______________________) { printf(x = %d\n, x); find = 1; } x++; } return 0; }

A、第5行: !find第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

B、第5行: find==1第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

C、第5行: find!=1第7行: x/2==1 && x/3==2 && x/5==4 && x/6==5 && x/7==0

D、第5行: find!=0第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

6、【单选题】鸡兔同笼,共有98个头,386只脚,编程求鸡、兔各多少只。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int x, y; for (x=1; _______; x++) { ____________; if (____________) { printf(x = %d, y = %d, x, y); } } return 0; }

A、第5行: x<=97第7行: y = 98 - x第8行: 2*x+4*y == 386

B、第5行: x<97第7行: x = 98 - y第8行: 2*x+4*y == 386

C、第5行: x<97第7行: y = 98 - x第8行: 2x+4y == 386

D、第5行: x<=97第7行: x = 98 - y第8行: 2*x+4*y <= 386

7、【单选题】以下能正确计算1×2×3×4...×10的程序段是

A、i=1; s=1; do { s=s*i; i++; } while(i<=10);

B、do { i=1; s=1; s=s*i; i++; } while(i<=10);

C、do { i=1; s=0; s=s*i; i++; } while(i<=10);

D、i=1; s=0; do { s=s*i; i++; } while(i<=10);

8、【单选题】以下程序执行后的输出结果是#include stdio.h int main( ) { int i,n=0; for(i=2;i5;i++) { do { if(i%3) continue; n++; }while(!i); n++; } printf(n=%d\n,n); return 0; }

A、n=4

B、 n=5

C、 n=2

D、 n=3

9、【单选题】以下正确的描述是

A、只能在循环体内和switch语句体内使用break语句

B、 continue语句的作用是结束整个循环的执行

C、在循环体内使用break语句或continue语句的作用相同

D、continue语句可以写在循环体之外

10、【单选题】计算直到最后一项的绝对值小于为止。‍代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include math.h int main() { int n = 1; float term = 1, sum = 0; ______________; while (fabs(term) = 1e-4) //判末项大小 { term = sign / n; //求出累加项 sum = sum + term; //累加 ________________; //改变项的符号 n++; //分母加1 } printf(sum = %f\n, sum); return 0; }

A、第7行代码: float sign=1第13行代码: sign = -sign

B、第7行代码: float sign= -1第13行代码: sign = -sign

C、第7行代码: float sign=1第13行代码: term = -term

D、第7行代码: float sign= -1第13行代码: term = -term

11、【单选题】设已定义i和k为int类型变量,则以下for循环语句for(i=0,k=-1;k=1; i++,k++) printf( * * * *\n);

A、是无限循环

B、判断循环结束的条件不合法

C、循环一次也不执行

D、循环只执行一次

12、【单选题】有以下程序,若从键盘给n输入的值是-3,则程序的输出结果是#include stdio.h int main() { int s=0,a=1,n; scanf(%d,n); do { s+=1; a=a-2; } while(a!=n); printf(%d\n,s); return 0; }

A、2

B、-1

C、3

D、0

13、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int i=0,s=0; for (;;) { if(i==3||i==5) continue; if (i==6) break; i++; s+=i; } printf(%d\n,s); return 0; }

A、程序进入死循环

B、10

C、13

D、21

14、【单选题】下面程序的功能是输出以下形式的图案,则在下划线处应填入的是 * *** ***** *******#include stdio.h int main( ) { int i,j; for(i=1;i=4;i++) { for(j=1;j=__________;j++) { printf(*); } printf(\n); } return 0; }

A、2*i-1

B、2*i+1

C、i+2

D、i

15、【单选题】程序执行后的输出结果是#include stdio.h int main( ) { int i,s=0; for(i=1;i10;i+=2) { s+=i+1; } printf(%d\n,s); return 0; }

A、自然数1~10中的偶数之和

B、自然数1~9的累加和

C、自然数1~10的累加和

D、自然数1~9中的奇数之和

16、【单选题】以下程序的输出结果是#include stdio.h int main() { int a, b; for(a=1, b=1; a=100; a++) { if(b=10) break; if (b%3==1) { b+=3; continue; } } printf(%d\n,a); return 0; }

A、4

B、101

C、6

D、5

17、【单选题】三色球问题。若一个口袋中放有12个球,其中有3个红色的,3个白色的,6个黑色的,从中任取8个球,问共有多少种不同的颜色搭配?‍代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int i, j, k; for (i=0; i=3; i++) { for (j=0; j=3; j++) { for (________________) { if (__________________) { printf(i=%d, j=%d, k=%d\n, i, j, k); } } } } return 0; }

A、第9行: k=0; k<=6; k++第11行: i + j + k == 8

B、第9行: k=0; k<=6; k++第11行: i + j + k = 8

C、第9行: k=0; k<=6; k++第11行: i + j + k <= 8

D、第9行: k=0; k<6; k++第11行: i + j + k == 8

18、【单选题】我国古代的《张丘建算经》中有这样一道著名的百鸡问题:“鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一。百钱买百鸡,问鸡翁、母、雏各几何?”其意为:公鸡每只5元,母鸡每只3元,小鸡3只1元。用100元买100只鸡,问公鸡、母鸡和小鸡各能买多少只?代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int x, y, z; for (x=0; x=20; x++) { for (y=0; _________; y++) { _______________; if (_______________) { printf(x=%d, y=%d, z=%d\n, x, y, z); } } } return 0; }

A、第7行: y<=33第9行: z = 100 – x - y第10行: 5*x + 3*y + z/3.0 == 100

B、第7行: y<=33第9行: z + y + x = 100第10行: 5*x + 3*y + z/3.0 = 100

C、第7行: y<=33第9行: z = 100 – x - y第10行: 5x + 3y + z/3.0 == 100

D、第7行: y<33第9行: z = 100 – x - y第10行: 5*x + 3*y + z/3.0 <= 100

19、【单选题】以下不是死循环的程序段是

A、int s=36; while (s) { --s; }

B、int i=100; while(1) { i=i%100+1; if (i>100) break; }

C、for( ; ;);

D、unsigned int k=0; do{ ++k; } while (k>=0);

20、【单选题】以下程序的功能是计算:s= 1+1/2+1/3+……+1/10,程序运行后输出结果错误,导致错误结果的程序行是#include stdio.h int main() { int n; float s; s=1.0; for(n=10;n1;n--) { s=s+1/n; } printf(%6.4f\n,s); return 0; }

A、s=s+1/n;

B、 printf("%6.4f\n",s);

C、for(n=10;n>1;n--)

D、s=1.0;

21、【单选题】以下程序运行时,从键盘输入:01回车,程序执行后的输出结果是#include stdio.h int main( ) { char k; int i; for(i=1;i3;i++) { scanf(%c,k); switch(k) { case '0': printf(another\n); case '1': printf(number\n); } } return 0; }

A、anothernumbernumber

B、numbernumber

C、anothernumber

D、anothernumberanother

22、【单选题】华氏和摄氏温度的转换公式为C=5/9×(F-32)。式中,C表示摄氏温度,F表示华氏温度。要求:华氏0℉~300℉,每隔20℉输出一个华氏温度对应的摄氏温度值。‍代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int upper = 300, step = 20; float fahr = 0, celsius; while (fahr upper) { _________________; printf(%4.0f\t%6.1f\n, fahr, celsius); ________________ ; } return 0; }

A、第8行代码: celsius = 5.0 / 9 * (fahr - 32)第10行代码: fahr = fahr + step

B、第8行代码: celsius = 5 / 9 * (fahr - 32)第10行代码: fahr = fahr + step

C、第8行代码: celsius = 5.0 / (9 * (fahr - 32))第10行代码: fahr = fahr + step

D、第8行代码: celsius = 5.0 / 9 * (fahr - 32)第10行代码: fahr = fahr - step

23、【单选题】利用泰勒级数:计算e的近似值,当最后一项的绝对值小于时认为达到了精度要求,要求统计总共累加了多少项。‍代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include math.h #include stdio.h int main() { int n = 1, count = 1; ________________; double term = 1.0; while (fabs(term) = 1e-5) //判末项大小 { ______________; //求出累加项 e = e + term; //累加 n++; // 计算下一项 _______________; //统计累加项数 } printf(e = %f, count = %d\n, e, count); return 0; }

A、第6行代码: double e = 1.0第10行代码: term = term / n第13行代码: count++

B、第6行代码: double e = 0第10行代码: term = term / n第13行代码: count++

C、第6行代码: double e = 1.0第10行代码: term = term *n第13行代码: count++

D、第6行代码: double e = 0第10行代码: term = term *n第13行代码: count++

24、【单选题】打印所有的“水仙花数”。所谓“水仙花数”,是指一个三位数,其各位数字的立方和等于该数本身。例如,153是“水仙花数”,因为 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int i, j, k, n; printf(result is:); for (n=100; ________; n++) { i = n / 100; //分离出百位 j = ____________; //分离出十位 k = ____________; //分离出个位 if (_________________________) { printf(%d\t ,n); //输出结果 } } printf(\n); return 0; }

A、第6行: n<1000第9行: (n - i * 100) / 10第10行:n % 10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

B、第6行: n<1000第9行: (n - i * 100) / 10第10行:n % 10第11行:i*100+j*10+k = i*i*i+j*j*j+k*k*k

C、第6行: n<=1000第9行: n % 100第10行:n % 10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

D、第6行: n<1000第9行: (n - i * 100) / 10第10行:n /10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

练兵区——单选题——不计入总分

1、【单选题】程序运行后的输出结果是#include stdio.h int main() { int i; for(i=0;i3;i++) switch(i) { case 0: printf(%d,i); case 2: printf(%d,i); default: printf(%d,i); } return 0; }

A、000122

B、022111

C、021021

D、012

2、【单选题】若变量已正确定义,要求程序段完成求5!的计算,不能完成此操作的程序段是

A、for( i=1; i<=5; i++ ){ p=1; p*=i;}

B、for(i=1,p=1;i<=5;i++) p*=i;

C、i=1; p=1; while ( i<=5 ) { p*=i; i++; }

D、i=1; p=1; do { p*=i; i++; } while ( i<=5 );

3、【单选题】下面程序的输出是#include stdio.h int main() { int y=9; for( ; y0; y--) { if(y%3==0) { printf(%d, --y); continue; } } return 0; }

A、852

B、741

C、963

D、875421

4、【单选题】爱因斯坦数学题。爱因斯坦曾出过这样一道数学题:有一条长阶梯,若每步跨2阶,最后剩下1阶;若每步跨3阶,最后剩下2阶;若每步跨5阶,最后剩下4阶;若每步跨6阶,最后剩下5阶;只有每步跨7阶,最后才正好1阶不剩。请问,这条阶梯共有多少阶?代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int x = 1, find = 0; while (__________) { if (______________________) { printf(x = %d\n, x); find = 1; } x++; } return 0; }

A、第5行: !find第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

B、第5行: find==1第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

C、第5行: find!=1第7行: x/2==1 && x/3==2 && x/5==4 && x/6==5 && x/7==0

D、第5行: find!=0第7行: x%2==1 && x%3==2 && x%5==4 && x%6==5 && x%7==0

5、【单选题】鸡兔同笼,共有98个头,386只脚,编程求鸡、兔各多少只。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int x, y; for (x=1; _______; x++) { ____________; if (____________) { printf(x = %d, y = %d, x, y); } } return 0; }

A、第5行: x<=97第7行: y = 98 - x第8行: 2*x+4*y == 386

B、第5行: x<97第7行: x = 98 - y第8行: 2*x+4*y == 386

C、第5行: x<97第7行: y = 98 - x第8行: 2x+4y == 386

D、第5行: x<=97第7行: x = 98 - y第8行: 2*x+4*y <= 386

6、【单选题】以下正确的描述是

A、只能在循环体内和switch语句体内使用break语句

B、 continue语句的作用是结束整个循环的执行

C、在循环体内使用break语句或continue语句的作用相同

D、continue语句可以写在循环体之外

7、【单选题】华氏和摄氏温度的转换公式为C=5/9×(F-32)。式中,C表示摄氏温度,F表示华氏温度。要求:华氏0℉~300℉,每隔20℉输出一个华氏温度对应的摄氏温度值。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int upper = 300, step = 20; float fahr = 0, celsius; while (fahr upper) { _________________; printf(%4.0f\t%6.1f\n, fahr, celsius); ________________ ; } return 0; }

A、第8行代码: celsius = 5.0 / 9 * (fahr - 32)第10行代码: fahr = fahr + step

B、第8行代码: celsius = 5 / 9 * (fahr - 32)第10行代码: fahr = fahr + step

C、第8行代码: celsius = 5.0 / (9 * (fahr - 32))第10行代码: fahr = fahr + step

D、第8行代码: celsius = 5.0 / 9 * (fahr - 32)第10行代码: fahr = fahr - step

8、【单选题】利用泰勒级数:计算e的近似值,当最后一项的绝对值小于时认为达到了精度要求,要求统计总共累加了多少项。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include math.h #include stdio.h int main() { int n = 1, count = 1; ________________; double term = 1.0; while (fabs(term) = 1e-5) //判末项大小 { ______________; //求出累加项 e = e + term; //累加 n++; // 计算下一项 _______________; //统计累加项数 } printf(e = %f, count = %d\n, e, count); return 0; }

A、第6行代码: double e = 1.0第10行代码: term = term / n第13行代码: count++

B、第6行代码: double e = 0第10行代码: term = term / n第13行代码: count++

C、第6行代码: double e = 1.0第10行代码: term = term *n第13行代码: count++

D、第6行代码: double e = 0第10行代码: term = term *n第13行代码: count++

9、【单选题】打印所有的“水仙花数”。所谓“水仙花数”,是指一个三位数,其各位数字的立方和等于该数本身。例如,153是“水仙花数”,因为代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int i, j, k, n; printf(result is:); for (n=100; ________; n++) { i = n / 100; //分离出百位 j = ____________; //分离出十位 k = ____________; //分离出个位 if (_________________________) { printf(%d\t ,n); //输出结果 } } printf(\n); return 0; }

A、第6行: n<1000第9行: (n - i * 100) / 10第10行:n % 10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

B、第6行: n<1000第9行: (n - i * 100) / 10第10行:n % 10第11行:i*100+j*10+k = i*i*i+j*j*j+k*k*k

C、第6行: n<=1000第9行: n % 100第10行:n % 10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

D、第6行: n<1000第9行: (n - i * 100) / 10第10行:n /10第11行:i*100+j*10+k == i*i*i+j*j*j+k*k*k

10、【单选题】以下程序执行后的输出结果是#include stdio.h int main( ) { int i,n=0; for(i=2;i5;i++) { do { if(i%3) continue; n++; }while(!i); n++; } printf(n=%d\n,n); return 0; }

A、n=4

B、n=5

C、n=2

D、n=3

11、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int i=0,s=0; for (;;) { if(i==3||i==5) continue; if (i==6) break; i++; s+=i; } printf(%d\n,s); return 0; }

A、程序进入死循环

B、10

C、13

D、21

12、【单选题】程序执行后的输出结果是#include stdio.h int main( ) { int i,s=0; for(i=1;i10;i+=2) { s+=i+1; } printf(%d\n,s); return 0; }

A、自然数1~10中的偶数之和

B、自然数1~9的累加和

C、自然数1~10的累加和

D、自然数1~9中的奇数之和

13、【单选题】以下程序运行时,从键盘输入:01回车,程序执行后的输出结果是#include stdio.h int main( ) { char k; int i; for(i=1;i3;i++) { scanf(%c,k); switch(k) { case '0': printf(another\n); case '1': printf(number\n); } } return 0; }

A、anothernumbernumber

B、numbernumber

C、anothernumber

D、anothernumberanother

14、【单选题】以下程序执行后的输出结果是#include stdio.h int main( ) { int x=0,y=5,z=3; while(z--0 ++x5) { y=y-1; } printf(%d,%d,%d\n,x,y,z); return 0; }

A、3,2,-1

B、3,2,0

C、4,3,-1

D、5,-2,-5

15、【单选题】以下能正确计算1×2×3×4...×10的程序段是

A、i=1; s=1; do { s=s*i; i++; } while(i<=10);

B、do { i=1; s=1; s=s*i; i++; } while(i<=10);

C、do { i=1; s=0; s=s*i; i++; } while(i<=10);

D、i=1;s=0;do { s=s*i; i++; } while(i<=10);

16、【单选题】下面程序的功能是输出以下形式的图案,则在下划线处应填入的是 * *** ***** *******#include stdio.h int main( ) { int i,j; for(i=1;i=4;i++) { for(j=1;j=__________;j++) { printf(*); } printf(\n); } return 0; }

A、2*i-1

B、2*i+1

C、i+2

D、i

17、【单选题】以下程序的输出结果是#include stdio.h int main() { int a, b; for(a=1, b=1; a=100; a++) { if(b=10) break; if (b%3==1) { b+=3; continue; } } printf(%d\n,a); return 0; }

A、4

B、101

C、6

D、5

18、【单选题】以下不是死循环的程序段是

A、int s=36; while (s) { --s; }

B、int i=100; while(1) { i=i%100+1; if (i>100) break; }

C、for( ; ;);

D、unsigned int k=0; do{ ++k; } while (k>=0);

19、【单选题】计算直到最后一项的绝对值小于为止。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include math.h int main() { int n = 1; float term = 1, sum = 0; ______________; while (fabs(term) = 1e-4) //判末项大小 { term = sign / n; //求出累加项 sum = sum + term; //累加 ________________; //改变项的符号 n++; //分母加1 } printf(sum = %f\n, sum); return 0; }

A、第7行代码: float sign=1第13行代码: sign = -sign

B、第7行代码: float sign= -1第13行代码: sign = -sign

C、第7行代码: float sign=1第13行代码: term = -term

D、第7行代码: float sign= -1第13行代码: term = -term

20、【单选题】设已定义i和k为int类型变量,则以下for循环语句for(i=0,k=-1;k=1; i++,k++) printf( * * * *\n);

A、是无限循环

B、判断循环结束的条件不合法

C、循环一次也不执行

D、循环只执行一次

21、【单选题】有以下程序,若从键盘给n输入的值是-3,则程序的输出结果是#include stdio.h int main() { int s=0,a=1,n; scanf(%d,n); do { s+=1; a=a-2; } while(a!=n); printf(%d\n,s); return 0; }

A、2

B、-1

C、3

D、0

22、【单选题】三色球问题。若一个口袋中放有12个球,其中有3个红色的,3个白色的,6个黑色的,从中任取8个球,问共有多少种不同的颜色搭配?代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int i, j, k; for (i=0; i=3; i++) { for (j=0; j=3; j++) { for (________________) { if (__________________) { printf(i=%d, j=%d, k=%d\n, i, j, k); } } } } return 0; }

A、第9行: k=0; k<=6; k++第11行: i + j + k == 8

B、第9行: k=0; k<=6; k++第11行: i + j + k = 8

C、第9行: k=0; k<=6; k++第11行: i + j + k <= 8

D、第9行: k=0; k<6; k++第11行: i + j + k == 8

23、【单选题】我国古代的《张丘建算经》中有这样一道著名的百鸡问题:“鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一。百钱买百鸡,问鸡翁、母、雏各几何?”其意为:公鸡每只5元,母鸡每只3元,小鸡3只1元。用100元买100只鸡,问公鸡、母鸡和小鸡各能买多少只?代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int main() { int x, y, z; for (x=0; x=20; x++) { for (y=0; _________; y++) { _______________; if (_______________) { printf(x=%d, y=%d, z=%d\n, x, y, z); } } } return 0;

A、第7行: y<=33第9行: z = 100 – x - y第10行: 5*x + 3*y + z/3.0 == 100

B、第7行: y<=33第9行: z + y + x = 100第10行: 5*x + 3*y + z/3.0 = 100

C、第7行: y<=33第9行: z = 100 – x - y第10行: 5x + 3y + z/3.0 == 100

D、第7行: y<33第9行: z = 100 – x - y第10行: 5*x + 3*y + z/3.0 <= 100

24、【单选题】以下程序的功能是计算:s= 1+1/2+1/3+……+1/10,程序运行后输出结果错误,导致错误结果的程序行是#include stdio.h int main() { int n; float s; s=1.0; for(n=10;n1;n--) { s=s+1/n; } printf(%6.4f\n,s); return 0; }

A、s=s+1/n;

B、 printf("%6.4f\n",s);

C、for(n=10;n>1;n--)

D、s=1.0;

函数的参数和返回值

1、【单选题】下列说法中错误的是()。

A、函数中的return语句可以有多个,但是多个return语句并不表示函数可以用return返回多个值,用return返回的函数值只能有一个。

B、在C语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。

C、形参也是局部变量,只能在函数体内访问。

D、在C语言中,实参与其对应的形参各占独立的存储单元,函数调用时的参数传递就是把实参的值复制一份给形参,即由实参向形参进行单向传值,因此形参值的变化不影响实参的值。

函数原型

1、【单选题】下列说法错误的是()。

A、当函数原型与函数定义中的形参类型不一致时,编译器一般都会指出参数类型不匹配的编译错误。因此,写上函数原型有助于编译器对函数参数进行类型匹配检查。

B、函数声明是一条语句,不包括函数体。

C、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。

D、函数调用时,要求实参与形参的数量相等,它们的类型也要匹配,匹配的原则与变量赋值的原则一致。当函数调用时的实参与函数定义中的形参的类型不匹配时,有的编译器会发出警告,提示有可能出现数据信息丢失,而有的编译器则不会发出警告。

函数封装与程序的健壮性

1、【单选题】下列说法错误的是()。

A、我们常将程序具有遇到不正确使用或非法数据输入时仍能保护自己避免出错的能力称为程序的健壮性。

B、在函数的入口处增加对函数参数合法性的检查以及对函数调用是否成功的检查,是一种常用的增强程序健壮性的方法。

C、对于一个封装好的函数,外界对函数的影响仅限于入口参数,函数对外界的影响仅限于函数的返回值和数组、指针形参 。

D、编译器给出的警告信息无关紧要,因此可以忽略。

断言

1、【单选题】下列说发错误的是()。

A、assert()其实是一个在<assert.h>中定义的宏,用来验证“不应该”发生的情况是否的确不会发生。

B、assert()的功能就是验证assert后括号内表达式值的真假,当该表达式的值为真时,它什么也不做。反之,则立即终止程序的执行,并报告错误,但是不会对错误采取其他处理措施。

C、在使用assert()时,必须在源文件中用编译预处理指令包含头文件<assert.h>。

D、断言不仅可以用于调试程序,还可以作为程序的功能,检查有可能发生的程序错误。

断言的使用场合

1、【多选题】在下列哪些情况下适合使用断言?

A、检查程序中的各种假设的正确性。

B、证实或测试某种不可能发生的状况确实不会发生。

C、捕捉不应该或者不可能发生的非法情况。

D、捕捉程序中有可能出现的错误。

函数名的命名

1、【多选题】下面所列举的函数名正确且具有良好风格的是()

A、2_abcd()

B、GetNumber()

C、change_directory()

D、chushihua@()

第6周编程题在线测试

练兵区——编程题——不计入总分

第6周测验

1、【单选题】下列说法中正确的是

A、函数原型是一条语句,不包括函数体。

B、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。

C、在C语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。

D、函数只有一个返回值,所以不能有多个return语句。

2、【单选题】以下程序有语法错误,有关错误原因的正确说法是#include stdio.h void prt_char(float x); int main() { int G=5,k; ...... k=prt_char(G); ...... return 0; } int prt_char(int x) { ...... }

A、函数原型和函数定义不匹配

B、变量名不能使用大写字母

C、函数名不能使用下划线

D、函数prt_char(int x)定义的位置不对,不能放在主函数main()的后面。

3、【单选题】以下程序的功能是选出能被3整除且至少有一位是5的两位数的整数,输出所有满足条件的数及其个数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int Sub(int k,int n) { int a1,a2; a2=k/10; a1=k-a2*10; if(________________) { printf(%4d,k); n++; return n; } else return -1; } int main() { int n=0,k,m; for(k=10;k100;k++) { m=__________; if(________) n=m; } printf(\nn=%d\n,n); return 0; }

A、第7行: (k%3==0&&a2==5)||(k%3==0&&a1==5)第22行: Sub(k,n)第24行: m!=-1

B、第7行:(k%3==0 &&a2==5) && (k%3==0 &&a1==5)第22行:Sub(n,k)第24行:m==-1

C、第7行:(k%3=0 && a2=5)||(k%3=0 && a1=5)第22行:Sub(k,n)第24行:m=-1

D、第7行:(k%3=0 && a2=5) && (k%3=0 && a1=5)第22行:Sub(n,k)第24行:m!=-1

4、【单选题】设计一个函数,用来判断一个整数是否为素数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include math.h #include stdio.h int IsPrimeNumber(int number); int main() { int n, ret; printf(Input n:); scanf(%d, n); ret = IsPrimeNumber(n); if (___________) { printf(%d is a prime number\n, n); } else { printf(%d is not a prime number\n, n); } return 0; } //函数功能:判断number是否是素数,函数返回非0值,表示是素数,否则不是素数 int IsPrimeNumber(int number) { int i; if (number = 1) return 0; // 负数、0和1都不是素数 for (i=2; ________________; i++) { if (_______________) // 被整除,不是素数 return 0; } return 1; }

A、第11行: ret != 0第29行: i<=sqrt(number)第31行: number % i == 0

B、第11行: ret == 0第29行: i<=number第31行: number % i == 0

C、第11行: ret == 0第29行: i<=sqrt(number)第31行: number / i == 0

D、第11行: ret != 0第29行: i<=number第31行: number / i == 0

5、【单选题】以下程序执行后的输出结果是void Fun(int v , int w) { int t; t=v; v=w; w=t; } int main( ) { int x=1,y=3,z=2; if(xy) Fun(x,y); else if(yz) Fun(y,z); else Fun(x,z); printf(%d,%d,%d\n,x,y,z); return 0; }

A、1,3,2

B、1,2,3

C、3,1,2

D、2,3,1

6、【单选题】若已定义的函数有返回值,则以下关于该函数调用的叙述中错误的是

A、函数调用可以作为一个函数的形参

B、函数调用可以作为独立的语句存在

C、函数调用可以作为一个函数的实参

D、函数调用可以出现在表达式中

7、【单选题】有以下函数定义:void Fun(int n, double x) { …… }若以下选项中的变量都已正确定义并赋值如下:int a,k;double b;a=12;b=0.45;则对函数Fun的正确调用语句是

A、Fun(a,b);

B、Fun(int y,double m);

C、k=Fun(10,12.5);

D、k=void Fun(a,b);

8、【单选题】设计一个函数MinCommonMultiple(),计算两个正整数的最小公倍数。‍代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int MinCommonMultiple(int a, int b); int main() { int a, b, x; printf(Input a,b:); scanf(%d,%d, a, b); x = _________________; if (__________) printf(MinCommonMultiple = %d\n, x); else printf(Input error!\n); return 0; } //函数功能:计算两个正整数的最小公倍数,-1表示没有最小公倍数 int MinCommonMultiple(int a, int b) { int i; if (_________________) return -1; // 保证输入的参数为正整数 for (i=1; ib; i++) { if (________________) return i * a; } return b * a; }

A、第8行: MinCommonMultiple(a, b)第10行: x != -1第22行: a<=0 || b<=0第26行: (i * a) % b == 0

B、第8行: MinCommonMultiple第10行: x == -1第22行: a<=0 && b<=0第26行: (i * a) % b == 0

C、第8行: MinCommonMultiple(b, a)第10行: x != -1第22行: a<=0 || b<=0第26行: (i * a) / b == 0

D、第8行: MinCommonMultiple(int a, int b)第10行: x = -1第22行: a<=0 || b<=0第26行: (i * a) % b == 0

9、【单选题】设计一个函数MaxCommonFactor(),利用欧几里德算法(也称辗转相除法)计算两个正整数的最大公约数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int MaxCommonFactor(int a, int b); int main() { int a, b, x; printf(Input a,b:); scanf(%d,%d, a, b); x =_______________ ; if (x != -1) { printf(MaxCommonFactor = %d\n, x); } else { printf(Input error!\n); } return 0; } //函数功能: 计算两个正整数的最大公约数,-1表示没有最大公约数 int MaxCommonFactor(int a, int b) { int r; if (a=0 || b=0) return -1; // 保证输入的参数为正整数 do{ ____________; a = b; _____________; }while (__________); return a; }

A、第8行: MaxCommonFactor(a, b)第29行: r = a % b第31行: b = r第32行: r != 0

B、第8行: MaxCommonFactor(a, b, x)第29行: r = a % b第31行: a = r第32行: r == 0

C、第8行: MaxCommonFactor(a, x)第29行: r = b % a第31行: b = r第32行: r = 0

D、第8行: MaxCommonFactor(x, b)第29行: r = a / b第31行: a = r第32行: r != 0

10、【单选题】C语言规定:在一个源程序中,main函数的位置

A、可以任意

B、必须在程序的最开始

C、必须在系统调用的库函数的后面

D、必须在程序的最后

11、【单选题】编程计算下面组合数的值代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h _________________________; int main() { int m, k; _________; do{ printf(Please input m,k (m=k0):); scanf(%d, %d, m, k); } while (______________); p = (double)Factorial(m) / (Factorial(k) * Factorial (m-k)); printf(p=%.0f\n, p); return 0; } //函数功能:计算无符号整型数number的阶乘 unsigned long Factorial(unsigned int number) { unsigned long i, result = 1; for (________________) { result *= i; } return result; }

A、第2行: unsigned long Factorial(unsigned int number)第6行: double p第11行: m<k || m<0 || k<0第23行: i=2; i<=number; i++

B、第2行: long Factorial(unsigned int number)第6行: double p第11行: m<k || m<0 || k<0第23行: i=1; i<number; i++

C、第2行: unsigned long Factorial(int number)第6行: int p第11行: m<k && m<0 && k<0第23行: i=2; i<=number; i++

D、第2行: unsigned Factorial(unsigned number)第6行: int p第11行: m<k || m<0 || k<0第23行: i=1; i<=number; i++

12、【单选题】完全数,又称完美数或完数(Perfect Number),它是指这样的一些特殊的自然数,它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身。例如,6就是一个完全数,是因为6 = 1 + 2 + 3。请编写一个判断完全数的函数IsPerfect(),然后判断从键盘输入的整数是否是完全数。注意:1没有真因子,所以不是完全数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h #include math.h int IsPerfect(int x); int main() { int m; printf(Input m:); scanf(%d, m); if (_________________) /* 完全数判定 */ printf(%d is a perfect number\n, m); else printf(%d is not a perfect number\n, m); return 0; } /* 函数功能:判断完全数,若函数返回0,则代表不是完全数,若返回1,则代表是完全数 */ int IsPerfect(int x) { int i; int total = 0; /* 1没有真因子,不是完全数 */ for (__________________) { if (___________) total = total + i; } return total==x ? 1 : 0; }

A、第10行: IsPerfect(m)第24行: i=1; i<x; i++第26行: x % i == 0

B、第10行: m第24行: i=1; i<=x; i++第26行: x % i != 0

C、第10行: IsPerfect(m)!=1第24行: i=0; i<=x; i++第26行: x / i == 0

D、第10行: IsPerfect(m)==0第24行: i=0; i<x; i++第26行: x % i != 0

13、【单选题】以下程序执行后输出结果是#include stdio.h int MaxValue(int x, int y) { return xy? x:y; } int MinValue(int x,int y) { return xy? y:x; } int main() { int a=4,b=3,c=5,d,e,f; d=MaxValue(a,b); d=MaxValue(d,c); e=MinValue(a,b); e=MinValue(e,c); f=a+b+c-d-e; printf(%d,%d,%d\n,d,f,e); return 0; }

A、5,4,3

B、3,4,5

C、 5,3,4

D、3,5,4

练兵区——单选题——不计入总分

1、【单选题】设计一个函数MaxCommonFactor(),利用欧几里德算法(也称辗转相除法)计算两个正整数的最大公约数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h int MaxCommonFactor(int a, int b); int main() { int a, b, x; printf(Input a,b:); scanf(%d,%d, a, b); x =_______________ ; if (x != -1) { printf(MaxCommonFactor = %d\n, x); } else { printf(Input error!\n); } return 0; } //函数功能: 计算两个正整数的最大公约数,-1表示没有最大公约数 int MaxCommonFactor(int a, int b) { int r; if (a=0 || b=0) return -1; // 保证输入的参数为正整数 do{ ____________; a = b; _____________; }while (__________); return a; }

A、第8行: MaxCommonFactor(a, b)第29行: r = a % b第31行: b = r第32行: r != 0

B、第8行: MaxCommonFactor(a, b, x)第29行: r = a % b第31行: a = r第32行: r == 0

C、第8行: MaxCommonFactor(a, x)第29行: r = b % a第31行: b = r第32行: r = 0

D、第8行: MaxCommonFactor(x, b)第29行: r = a / b第31行: a = r第32行: r != 0

2、【单选题】C语言规定:在一个源程序中,main函数的位置

A、可以任意

B、必须在程序的最开始

C、必须在系统调用的库函数的后面

D、必须在程序的最后

3、【单选题】以下程序执行后输出结果是#include stdio.h int MaxValue(int x, int y) { return xy? x:y; } int MinValue(int x,int y) { return xy? y:x; } int main() { int a=4,b=3,c=5,d,e,f; d=MaxValue(a,b); d=MaxValue(d,c); e=MinValue(a,b); e=MinValue(e,c); f=a+b+c-d-e; printf(%d,%d,%d\n,d,f,e); return 0; }

A、5,4,3

B、3,4,5

C、5,3,4

D、3,5,4

4、【单选题】有以下函数定义:void Fun(int n, double x) { …… }若以下选项中的变量都已正确定义并赋值如下:int a,k;double b;a=12;b=0.45;则对函数Fun的正确调用语句是

A、Fun(a,b);

B、Fun(int y,double m);

C、k=Fun(10,12.5);

D、k=void Fun(a,b);

5、【单选题】完全数,又称完美数或完数(Perfect Number),它是指这样的一些特殊的自然数,它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身。例如,6就是一个完全数,是因为6 = 1 + 2 + 3。请编写一个判断完全数的函数IsPerfect(),然后判断从键盘输入的整数是否是完全数。注意:1没有真因子,所以不是完全数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include math.h int IsPerfect(int x); int main() { int m; printf(Input m:); scanf(%d, m); if (_________________) /* 完全数判定 */ printf(%d is a perfect number\n, m); else printf(%d is not a perfect number\n, m); return 0; } /* 函数功能:判断完全数,若函数返回0,则代表不是完全数,若返回1,则代表是完全数 */ int IsPerfect(int x) { int i; int total = 0; /* 1没有真因子,不是完全数 */ for (__________________) { if (___________) total = total + i; } return total==x ? 1 : 0; }

A、第10行: IsPerfect(m)第24行: i=1; i<x; i++第26行: x % i == 0

B、第10行: m第24行: i=1; i<=x; i++第26行: x % i != 0

C、第10行: IsPerfect(m)!=1第24行: i=0; i<=x; i++第26行: x / i == 0

D、第10行: IsPerfect(m)==0第24行: i=0; i<x; i++第26行: x % i != 0

6、【单选题】下列说法中正确的是

A、函数原型是一条语句,不包括函数体。

B、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。

C、在C语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。

D、函数只有一个返回值,所以不能有多个return语句。

7、【单选题】以下程序有语法错误,有关错误原因的正确说法是#include stdio.h void prt_char(); int main() { int G=5,k; ...... k=prt_char(G); ...... return 0; } int prt_char(int x) { ...... }

A、函数原型和函数定义不匹配

B、变量名不能使用大写字母

C、函数名不能使用下划线

D、函数prt_char(int x)定义的位置不对,不能放在主函数main()的后面。

8、【单选题】以下程序的功能是选出能被3整除且至少有一位是5的两位数的整数,输出所有满足条件的数及其个数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int Sub(int k,int n) { int a1,a2; a2=k/10; a1=k-a2*10; if(________________) { printf(%4d,k); n++; return n; } else return -1; } int main() { int n=0,k,m; for(k=10;k100;k++) { m=__________; if(________) n=m; } printf(\nn=%d\n,n); return 0; }

A、第7行: (k%3==0&&a2==5)||(k%3==0&&a1==5)第22行: Sub(k,n)第24行: m!=-1

B、第7行:(k%3==0 &&a2==5) && (k%3==0 &&a1==5)第22行:Sub(n,k)第24行:m==-1

C、第7行:(k%3=0 && a2=5)||(k%3=0 && a1=5)第22行:Sub(k,n)第24行:m=-1

D、第7行:(k%3=0 && a2=5) && (k%3=0 && a1=5)第22行:Sub(n,k)第24行:m!=-1

9、【单选题】设计一个函数,用来判断一个整数是否为素数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include math.h #include stdio.h int IsPrimeNumber(int number); int main() { int n, ret; printf(Input n:); scanf(%d, n); ret = IsPrimeNumber(n); if (___________) { printf(%d is a prime number\n, n); } else { printf(%d is not a prime number\n, n); } return 0; } //函数功能:判断number是否是素数,函数返回非0值,表示是素数,否则不是素数 int IsPrimeNumber(int number) { int i; if (number = 1) return 0; // 负数、0和1都不是素数 for (i=2; ________________; i++) { if (_______________) // 被整除,不是素数 return 0; } return 1; }

A、第11行: ret != 0第29行: i<=sqrt(number)第31行: number % i == 0

B、第11行: ret == 0第29行: i<=number第31行: number % i == 0

C、第11行: ret == 0第29行: i<=sqrt(number)第31行: number / i == 0

D、第11行: ret != 0第29行: i<=number第31行: number / i == 0

10、【单选题】以下程序执行后的输出结果是void Fun(int v , int w) { int t; t=v; v=w; w=t; } int main( ) { int x=1,y=3,z=2; if(xy) Fun(x,y); else if(yz) Fun(y,z); else Fun(x,z); printf(%d,%d,%d\n,x,y,z); return 0; }

A、1,3,2

B、1,2,3

C、3,1,2

D、2,3,1

11、【单选题】若已定义的函数有返回值,则以下关于该函数调用的叙述中错误的是

A、函数调用可以作为一个函数的形参

B、函数调用可以作为独立的语句存在

C、函数调用可以作为一个函数的实参

D、函数调用可以出现在表达式中

12、【单选题】设计一个函数MinCommonMultiple(),计算两个正整数的最小公倍数。代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int MinCommonMultiple(int a, int b); int main() { int a, b, x; printf(Input a,b:); scanf(%d,%d, a, b); x = _________________; if (__________) printf(MinCommonMultiple = %d\n, x); else printf(Input error!\n); return 0; } //函数功能:计算两个正整数的最小公倍数,-1表示没有最小公倍数 int MinCommonMultiple(int a, int b) { int i; if (_________________) return -1; // 保证输入的参数为正整数 for (i=1; ib; i++) { if (________________) return i * a; } return b * a; }

A、第8行: MinCommonMultiple(a, b)第10行: x != -1第22行: a<=0 || b<=0第26行: (i * a) % b == 0

B、第8行: MinCommonMultiple第10行: x == -1第22行: a<=0 && b<=0第26行: (i * a) % b == 0

C、第8行: MinCommonMultiple(b, a)第10行: x != -1第22行: a<=0 || b<=0第26行: (i * a) / b == 0

D、第8行: MinCommonMultiple(int a, int b)第10行: x = -1第22行: a<=0 || b<=0第26行: (i * a) % b == 0

13、【单选题】编程计算下面组合数的值代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h _________________________; int main() { int m, k; _________; do{ printf(Please input m,k (m=k0):); scanf(%d, %d, m, k); } while (______________); p = (double)Factorial(m) / (Factorial(k) * Factorial (m-k)); printf(p=%.0f\n, p); return 0; } //函数功能:计算无符号整型数number的阶乘 unsigned long Factorial(unsigned int number) { unsigned long i, result = 1; for (________________) { result *= i; } return result; }

A、第2行: unsigned long Factorial(unsigned int number)第6行: double p第11行: m<k || m<0 || k<0第23行: i=2; i<=number; i++

B、第2行: long Factorial(unsigned int number)第6行: double p第11行: m<k || m<0 || k<0第23行: i=1; i<number; i++

C、第2行: unsigned long Factorial(int number)第6行: int p第11行: m<k && m<0 && k<0第23行: i=2; i<=number; i++

D、第2行: unsigned Factorial(unsigned number)第6行: int p第11行: m<k || m<0 || k<0第23行: i=1; i<=number; i++

函数的嵌套调用和递归调用

1、【单选题】下列说法错误的是()

A、函数既可以嵌套定义,也可以嵌套调用。

B、函数直接或间接调用自己,称为递归调用。

C、一个递归算法必须包含一般条件和基本条件两个基本要素。

D、基本条件是一个能控制递归过程结束的条件,是递归的出口,它本身不再使用递归的方式来定义。一般条件定义了递归关系,控制递归调用向着基本条件的方向转化。

递归的数学基础

1、【判断题】数学归纳法是递归的数学基础。

A、正确

B、错误

递归算法的执行过程

1、【判断题】递归算法的执行过程可分为递推和回归两个阶段。在递推阶段,必须要有终止递归的情况。当满足递归终止条件时,即获得最简单情况的解以后,开始进入回归阶段,即递归返回阶段。

A、正确

B、错误

尾递归

1、【判断题】当递归调用是整个函数体中最后执行的语句且它的返回值不属于任何表达式的一部分(即在回归阶段不需要任何计算)时,这种递归调用就是尾递归。

A、正确

B、错误

变量的作用域

1、【单选题】下列说法错误的是()。

A、变量的作用域是指变量的作用范围,即在程序中可以被读写访问的区域,它取决于变量被定义的位置。

B、局部变量与全局变量同名时,全局变量隐藏局部变量,即全局变量起作用,局部变量不起作用。

C、形参也是局部变量,形参变量和实参变量的作用域是不同的,因此形参变量和实参变量同名时,二者互不干扰。

D、只要同名的变量出现在不同的作用域内,二者互不干扰,编译器有能力区分不同作用域中的同名变量

全局变量的副作用

1、【判断题】全局变量破坏了函数的封装性,不能实现信息隐藏,依赖全局变量的函数很难在其他程序中复用,对于使用全局变量的程序维护也比较困难,因此建议尽量不用全局变量。

A、正确

B、错误

变量的存储类型与变量的作用域

1、【单选题】下列说法错误的是()。

A、变量的作用域决定了变量可以被访问的范围,而变量的存储类型决定了变量的生存期。

B、静态变量和全局变量都是在静态存储区中分配内存的,而自动变量是在动态存储区中分配内存的。

C、用extern声明变量为外部变量的时候,编译器是对其分配内存的。

D、静态局部变量和静态全局变量的生存期是相同的,但二者的作用域是不同的,而静态局部变量和自动变量的作用域都是局部的,但二者的生存期是不同的。

第7周编程题在线测试

练兵区——编程题——不计入总分

第7周测验

1、【单选题】下列说法正确的是

A、递归算法的执行过程可分为递推和回归两个阶段。在递推阶段,必须要有终止递归的情况。当满足递归终止条件时,即获得最简单情况的解以后,开始进入回归阶段,即递归返回阶段。

B、基本条件是一个能控制递归过程结束的条件,是递归的出口,它本身不再使用递归的方式来定义。一般条件定义了递归关系,控制递归调用向着基本条件的方向转化。

C、数学归纳法是递归的数学基础。

D、形参也是局部变量,形参变量和实参变量的作用域是不同的,因此形参变量和实参变量同名时,二者互不干扰。

E、全局变量破坏了函数的封装性,不能实现信息隐藏,依赖全局变量的函数很难在其他程序中复用,对于使用全局变量的程序维护也比较困难,因此建议尽量不用全局变量。

F、函数既可以嵌套定义,也可以嵌套调用。

G、局部变量与全局变量同名时,全局变量隐藏局部变量,即全局变量起作用,局部变量不起作用。

H、用extern声明变量为外部变量的时候,编译器是对其分配内存的。

I、静态局部变量和静态全局变量的生存期和作用域都是相同的。

2、【单选题】以下程序运行后的输出结果是#include stdio.h float Fun(int x,int y) { return(x+y); } int main() { int a=2,b=5,c=8; printf(%3.0f\n,Fun((int)Fun(a+c,b),a-c)); return 0; }

A、9

B、21

C、9.0

D、编译出错

3、【单选题】子函数Fun(int a, int b)的功能是,对任意两个整数a和b,返回两者中的最大值。以下程序是通过调用子函数Fun(int a, int b),找到三个整数中的最大值。若程序运行后的输出结果是8,请补充完整空白处缺少的代码。#include stdio.h int Fun(int a, int b) { if(ab) return_________; else return________; } int main() { int x=3, y=8, z=6, r; r=_______________; // 找到三个整数x,y,z中的最大值 printf(%d, r); return 0; }

A、第4行: a第5行: b第11行: Fun(Fun(x,y),z)

B、第4行: b第5行: a第11行: Fun(x,y,z)

C、第4行: 1第5行: 0第11行: Fun(x,y,z)

D、第4行: 0第5行: 1第11行: Fun(Fun(x,y),z)

4、【单选题】写出下面程序的运行结果#include stdio.h void Bin(int x) { if (x/2 0) Bin(x/2); printf(%d\n, x%2); } int main() { Bin(12); return 0; }

A、1100

B、0011

C、6310

D、6311

5、【单选题】下面程序是用辗转相除法计算两个正整数的最大公约数的递归求解方法。请将程序补充完整。提示:辗转相除法的基本思路是,对正整数a和b,连续进行求余运算,直到余数为0为止,此时非0的除数就是最大公约数。设r=a mod b表示a除以b的余数,若r≠0,则将b作为新的a,r作为新的b,重复a mod b运算,直到r=0时为止,此时b为所求的最大公约数。例如,50和15的最大公约数的求解过程可表示为:Gcd(50, 15)=Gcd(15, 5)=Gcd(5, 0)=5。int Gcd(int a, int b) { if (a%b == 0) return b; else return ____________________; }

A、Gcd(b, a%b)

B、Gcd(a, b%a)

C、Gcd(b%a, a)

D、Gcd(a%b, b)

6、【单选题】以下程序的输出结果是 #include stdio.h int Func(); int i=10; int main() { int j=1; j=Func(); printf(%d,,j); j=Func(); printf(%d,j); return 0; } int Func() { int k=0; k=k+i; i=i+10; return(k); }

A、10,20

B、0,0

C、10,10

D、20,20

7、【单选题】子函数Incre()的功能是,利用静态变量,使子函数的输出值能够随调用次数的增加依次为:第1次调用,输出:的结果第2次调用,输出:的结果第3次调用,输出:的结果.....在下面的程序中,对子函数Incre()进行了两次调用,若使程序的输出结果是:26请补充完整空白处缺少的代码。#include stdio.h int x=3; void Incre(); int main() { int i; for (i=1;_______;i++) Incre(); return 0; } void Incre() { ___________; x*=x+1; printf(%d\n,x); }

A、第7行: i<x第13行: static int x=1

B、第7行: i<=x第13行: static int x=0

C、第7行: i<x第13行: int x=1

D、第7行: i<=x第13行: int x=0

8、【单选题】请给出程序的运行结果。#include stdio.h int Fun(int m) { static int n = 0; m /= 2; m = m * 2; if (m) { n *= m; return(Fun(m - 2)); } else return n; } int main() { int a, i; for (i = 0; i 2; i++) { a = Fun(4 + i); printf(%d\n, a); } return 0; }

A、00

B、88

C、44

D、6464

9、【单选题】写出下面程序的运行结果。#include stdio.h int Square(int i) { return i * i; } int main(void) { int i = 0; i = Square(i); for ( ; i3; i++) { static int i = 1; i += Square(i); printf(%d,, i); } printf(%d\n, i); return 0; }

A、2,6,42,3

B、2,2,2,3

C、2,2,3,3

D、2,3,4,3

10、【单选题】根据最大公约数的如下3条性质,采用递归法编写计算最大公约数的函数Gcd(),在主函数中调用该函数计算并输出从键盘任意输入的两正整数的最大公约数。性质1 如果ab,则a和b与a-b和b的最大公约数相同,即Gcd(a, b) = Gcd(a-b, b)性质2 如果ba,则a和b与a和b-a的最大公约数相同,即Gcd(a, b) = Gcd(a, b-a)性质3 如果a=b,则a和b的最大公约数与a值和b值相同,即Gcd(a, b) = a = b代码如下,请补充程序中缺少的内容。#include stdio.h int Gcd(int a, int b); int main() { int a, b, c; printf(Input a,b:); scanf(%d,%d, a, b); c = Gcd(a, b); if (_________) printf(Greatest Common Divisor of %d and %d is %d\n, a, b, c); else printf(Input number should be positive!\n); return 0; } int Gcd(int a, int b) { if (_______________) return -1; if (a == b) return __________; else if (a b) return __________; else return ___________; }

A、第9行: c!= -1第18行: a <= 0 || b <= 0第21行: a第23行: Gcd(a - b, b)第25行: Gcd(a, b - a)

B、第9行: c== -1第18行: a <= 0 && b <= 0第21行: a第23行: Gcd(a - b, b)第25行: Gcd(a, b - a)

C、第9行: c!= -1第18行: a <= 0 && b <= 0第21行: b第23行: Gcd(a, b - a)第25行: Gcd(a - b, b)

D、第9行: c== -1第18行: a <= 0 || b <= 0第21行: a第23行: Gcd(a, b - a)第25行: Gcd(a - b, b)

11、【单选题】函数Sum(int n)是用递归方法计算下面的公式,请补充程序中缺少的内容。int Sum(int n) { if (n = 0) printf(data error\n); if (n == 1)_________________; else return ____________________; }

A、第4行: return 1第5行: n+Sum(n-1)

B、第4行: return 0第5行: Sum(n-1)

C、第4行: return 1第5行: Sum(n-1)

D、第4行: return 0第5行: Sum(n)

12、【单选题】下面函数是求阶乘的递归函数,请将程序补充完整。long Fact(int n) { if (n 0) return 0; if (n==1 || n==0) __________________; else ____________________; }

A、第4行: return 1 第5行: return n*Fact(n-1)

B、第4行: return 0 第5行: return n*Fact(n-1)

C、第4行: return -1 第5行: return (n-1)*Fact(n)

D、第4行: return 1 第5行: return Fact(n-1)

13、【单选题】Y()是实现n层嵌套平方根计算的函数,其公式如下,请将程序补充完整。double Y(double x, int n) { if (n == 0) return 0; else return (square(x +___________________)); }

A、Y(x,n-1)

B、Y(x,n)

C、Y(x,n+1)

D、Y(x,1)

14、【单选题】程序运行后的输出结果是#include stdio.h int Fun(int n) { if (n==1) return 1; else return Fun(n-1)+1; } int main() { int i,j=0; for(i=1;i3;i++) j+=Fun(i); printf(%d\n,j); return 0; }

A、3

B、4

C、2

D、1

15、【单选题】子函数Fun(char x , char y)的功能是对任意两个字符x和y,如果x为真,则函数返回y的值,否则返回x的值。若使以下程序运行后的输出结果是7,请补充完整空白处缺少的代码。#include stdio.h char Fun(char x , char y) { if(__________) return y; else return x; } int main( ) { char a='9',b='8',c='7'; printf(____,Fun(_______________)); return 0; }

A、第4行: x第11行:%c Fun(a,b),Fun(b,c)

B、第4行: x=0第11行:%d Fun(b,c),Fun(a,b)

C、第4行: x==0第11行:%c Fun(b,a),Fun(c,b)

D、第4行: x!=0第11行:%d Fun(c,b),Fun(b,a)

练兵区——单选题——不计入总分

1、【单选题】写出下面程序的运行结果#include stdio.h void Bin(int x) { if (x/2 0) Bin(x/2); printf(%d\n, x%2); } int main() { Bin(12); return 0;

A、1100

B、0011

C、6310

D、6311

2、【单选题】子函数Incre()的功能是,利用静态变量,使子函数的输出值能够随调用次数的增加依次为:第1次调用,输出:的结果第2次调用,输出:的结果第3次调用,输出:的结果.....在下面的程序中,对子函数Incre()进行了两次调用,若使程序的输出结果是:26请补充完整空白处缺少的代码。#include stdio.h int x=3; void Incre(); int main() { int i; for (i=1;_______;i++) Incre(); return 0; } void Incre() { ___________; x*=x+1; printf(%d\n,x); }

A、第7行: i<x第13行: static int x=1

B、第7行: i<=x第13行: static int x=0

C、第7行: i<x第13行: int x=1

D、第7行: i<=x第13行: int x=0

3、【单选题】函数Sum(int n)是用递归方法计算下面的公式,请补充程序中缺少的内容。int Sum(int n) { if (n = 0) printf(data error\n); if (n == 1)_________________; else return ____________________; }

A、第4行: return 1第5行: n+Sum(n-1)

B、第4行: return 0第5行: Sum(n-1)

C、第4行: return 1第5行: Sum(n-1)

D、第4行: return 0第5行: Sum(n)

4、【单选题】程序运行后的输出结果是#include stdio.h int Fun(int n) { if (n==1) return 1; else return Fun(n-1)+1; } int main() { int i,j=0; for(i=1;i3;i++) j+=Fun(i); printf(%d\n,j); return 0; }

A、3

B、4

C、2

D、1

5、【单选题】以下程序运行后的输出结果是#include stdio.h float Fun(int x,int y) { return(x+y); } int main() { int a=2,b=5,c=8; printf(%3.0f\n,Fun((int)Fun(a+c,b),a-c)); return 0; }

A、9

B、21

C、9.0

D、编译出错

6、【单选题】Y()是实现n层嵌套平方根计算的函数,其公式如下,请将程序补充完整。double Y(double x, int n) { if (n == 0) return 0; else return (square(x +___________________)); }

A、Y(x,n-1)

B、Y(x,n)

C、Y(x,n+1)

D、Y(x,1)

7、【单选题】下面程序是用辗转相除法计算两个正整数的最大公约数的递归求解方法。请将程序补充完整。提示:辗转相除法的基本思路是,对正整数a和b,连续进行求余运算,直到余数为0为止,此时非0的除数就是最大公约数。设r=a mod b表示a除以b的余数,若r≠0,则将b作为新的a,r作为新的b,重复a mod b运算,直到r=0时为止,此时b为所求的最大公约数。例如,50和15的最大公约数的求解过程可表示为:Gcd(50, 15)=Gcd(15, 5)=Gcd(5, 0)=5。int Gcd(int a, int b) { if (a%b == 0) return b; else return ____________________; }

A、Gcd(b, a%b)

B、Gcd(a, b%a)

C、Gcd(b%a, a)

D、Gcd(a%b, b)

8、【单选题】下面函数是求阶乘的递归函数,请将程序补充完整。long Fact(int n) { if (n 0) return 0; if (n==1 || n==0) __________________; else ____________________; }

A、第4行: return 1 第5行: return n*Fact(n-1)

B、第4行: return 0第5行: return n*Fact(n-1)

C、第4行: return -1 第5行: return (n-1)*Fact(n)

D、第4行: return 1 第5行: return Fact(n-1)

9、【单选题】子函数Fun(char x , char y)的功能是对任意两个字符x和y,如果x为真,则函数返回y的值,否则返回x的值。若使以下程序运行后的输出结果是7,请补充完整空白处缺少的代码。#include stdio.h char Fun(char x , char y) { if(__________) return y; else return x; } int main( ) { char a='9',b='8',c='7'; printf(____,Fun(_______________)); return 0; }

A、第4行: x第11行:%c Fun(a,b),Fun(b,c)

B、第4行: x=0第11行:%d Fun(b,c),Fun(a,b)

C、第4行: x==0第11行:%c Fun(b,a),Fun(c,b)

D、第4行: x!=0第11行:%d Fun(c,b),Fun(b,a)

10、【单选题】下列说法正确的是

A、递归算法的执行过程可分为递推和回归两个阶段。在递推阶段,必须要有终止递归的情况。当满足递归终止条件时,即获得最简单情况的解以后,开始进入回归阶段,即递归返回阶段。

B、基本条件是一个能控制递归过程结束的条件,是递归的出口,它本身不再使用递归的方式来定义。一般条件定义了递归关系,控制递归调用向着基本条件的方向转化。

C、数学归纳法是递归的数学基础。

D、形参也是局部变量,形参变量和实参变量的作用域是不同的,因此形参变量和实参变量同名时,二者互不干扰。

E、全局变量破坏了函数的封装性,不能实现信息隐藏,依赖全局变量的函数很难在其他程序中复用,对于使用全局变量的程序维护也比较困难,因此建议尽量不用全局变量。

F、函数既可以嵌套定义,也可以嵌套调用。

G、局部变量与全局变量同名时,全局变量隐藏局部变量,即全局变量起作用,局部变量不起作用。

H、用extern声明变量为外部变量的时候,编译器是对其分配内存的。

I、静态局部变量和静态全局变量的生存期和作用域都是相同的。

11、【单选题】子函数Fun(int a, int b)的功能是,对任意两个整数a和b,返回两者中的最大值。以下程序是通过调用子函数Fun(int a, int b),找到三个整数中的最大值。若程序运行后的输出结果是8,请补充完整空白处缺少的代码。#include stdio.h int Fun(int a, int b) { if(ab) return_________; else return________; } int main() { int x=3, y=8, z=6, r; r=_______________; // 找到三个整数x,y,z中的最大值 printf(%d, r); return 0; }

A、第4行: a第5行: b第11行: Fun(Fun(x,y),z)

B、第4行: b第5行: a第11行: Fun(x,y,z)

C、第4行: 1第5行: 0第11行: Fun(x,y,z)

D、第4行: 0第5行: 1第11行: Fun(Fun(x,y),z)

12、【单选题】以下程序的输出结果是 #include stdio.h int Func(); int i=10; int main() { int j=1; j=Func(); printf(%d,,j); j=Func(); printf(%d,j); return 0; } int Func() { int k=0; k=k+i; i=i+10; return(k); }

A、10,20

B、0,0

C、10,10

D、20,20

13、【单选题】请给出程序的运行结果#include stdio.h int Fun(int m) { static int n = 0; m /= 2; m = m * 2; if (m) { n *= m; return(Fun(m - 2)); } else return n; } int main() { int a, i; for (i = 0; i 2; i++) { a = Fun(4 + i); printf(%d\n, a); } return 0; }

A、00

B、88

C、44

D、6464

14、【单选题】写出下面程序的运行结果。#include stdio.h int Square(int i) { return i * i; } int main(void) { int i = 0; i = Square(i); for ( ; i3; i++) { static int i = 1; i += Square(i); printf(%d,, i); } printf(%d\n, i); return 0; }

A、2,6,42,3

B、2,2,2,3

C、2,2,3,3

D、2,3,4,3

15、【单选题】根据最大公约数的如下3条性质,采用递归法编写计算最大公约数的函数Gcd(),在主函数中调用该函数计算并输出从键盘任意输入的两正整数的最大公约数。性质1 如果ab,则a和b与a-b和b的最大公约数相同,即Gcd(a, b) = Gcd(a-b, b)性质2 如果ba,则a和b与a和b-a的最大公约数相同,即Gcd(a, b) = Gcd(a, b-a)性质3 如果a=b,则a和b的最大公约数与a值和b值相同,即Gcd(a, b) = a = b代码如下,请补充程序中缺少的内容。#include stdio.h int Gcd(int a, int b); int main() { int a, b, c; printf(Input a,b:); scanf(%d,%d, a, b); c = Gcd(a, b); if (_________) printf(Greatest Common Divisor of %d and %d is %d\n, a, b, c); else printf(Input number should be positive!\n); return 0; } int Gcd(int a, int b) { if (_______________) return -1; if (a == b) return __________; else if (a b) return __________; else return ___________; }

A、第9行: c!= -1第18行: a <= 0 || b <= 0第21行: a第23行: Gcd(a - b, b)第25行: Gcd(a, b - a)

B、第9行: c== -1第18行: a <= 0 && b <= 0第21行: a第23行: Gcd(a - b, b)第25行: Gcd(a, b - a)

C、第9行: c!= -1第18行: a <= 0 && b <= 0第21行: b第23行: Gcd(a, b - a)第25行: Gcd(a - b, b)

D、第9行: c== -1第18行: a <= 0 || b <= 0第21行: a第23行: Gcd(a, b - a)第25行: Gcd(a - b, b)

数组的定义和初始化

1、【单选题】下列说法错误的是()。

A、C语言中的二维数组在内存中是按列存储的。

B、在C语言中,数组的下标都是从0开始的。

C、在C语言中,不带下标的数组名代表数组的首地址,即第一个元素在内存中的地址。

D、C89规定不能使用变量定义数组的大小,但是在访问数组元素时在下标中可以使用变量或表达式。

数组做函数参数

1、【单选题】下列说法错误的是()。

A、简单变量做函数参数时,是将实参的值传给形参,实参和形参在内存中占用不同的存储单元,因此形参值的改变不会影响实参。

B、数组做函数参数时,是将实参数组的首地址传给形参,形参数组和实参数组在内存中共享相同的存储单元,因此对形参数组元素值的修改也就相当于是对实参数组元素值的修改。

C、在声明函数的二维数组形参时,可省略数组第二维的长度,但不能省略数组第一维的长度。

D、在声明函数的一维数组形参时,通常不指定数组的大小,而用另一个形参来指定数组的大小。

计算最大值

1、【判断题】在计算一组数据的最大值之前,通常假设这组数据中的第一个数为最大,即用这组数据中的第一个数为存放最大值的变量初始化。

A、正确

B、错误

线性查找与二分查找

1、【判断题】线性查找算法不要求数据表是已排好序的,而二分查找算法要求数据表是已排好序的。

A、正确

B、错误

二分查找算法的基本思想

1、【判断题】二分查找算法就是先将表的中间位置记录的关键字与查找关键字相比较,如果两者相等,则查找成功,否则将表分成前、后两个子表,根据比较结果,决定查找前一子表还是后一子表。

A、正确

B、错误

第8周编程题在线测试

练兵区——编程题——不计入总分

第8周测验

1、【单选题】输入某班学生某门课的成绩(最多不超过40人,具体人数由用户键盘输入),用函数编程统计不及格人数。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 40 intGetFailNum(int score[], int n); int main() { int i, n, fail, score[N]; printf(How many students?); scanf(%d, n); for (i=0; in; i++) { scanf(%d, _________); } fail = _____________; printf(Fail students = %d\n, fail); return 0; } /* 函数功能:统计不及格人数 */ int GetFailNum(int score[], int n) { int i, count = 0; for (i=0; in; i++) { if (_________) count++; } return count; }

A、第11行: &score[i]第13行: GetFailNum(score, n)第23行: score[i] < 60

B、第11行: score[i]第13行: GetFailNum(score, n)第23行: score[i] <= 60

C、第11行: score[i]第13行: GetFailNum(n,score)第23行: score[i] < 60

D、第11行: &score[i]第13行: GetFailNum(score[i], n)第23行: score[i] >= 60

2、【单选题】输入n×n阶矩阵,用函数编程计算并输出其两条对角线上的各元素之和。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 10 void InputMatrix(int a[N][N], int n); int AddDiagonal(int a[N][N], int n); int main() { int a[N][N], n, sum; printf(Input n:); scanf(%d, n); InputMatrix(a, n); sum = AddDiagonal(a, n); printf(sum = %d\n, sum); return 0; } /* 函数功能: 输入n×n矩阵的元素值,存于数组a中 */ void InputMatrix(___________, int n) { int i, j; printf(Input %d*%d matrix:\n, n, n); for (i=0; in; i++) { for (j=0; jn; j++) { scanf(%d,___________); } } } /* 函数功能: 计算n×n矩阵中两条对角线上的元素之和 */ int AddDiagonal(int a[N][N], int n) { int i, j, sum = 0; for (i=0; in; i++) { for (j=0; jn; j++) { if (________________) sum = sum + a[i][j]; } } return ____________; }

A、第17行: int a[N][N]第25行: &a[i][j]第38行: i==j || i+j==n-1第42行: sum

B、第17行: int a[N][N]第25行: &a[i][j]第38行: i==j && i+j==n-1第42行: a[i][j]

C、第17行: int a[N][N]第25行: a[i][j]第38行: i==j || i+j==n-1第42行: a[N][N]

D、第17行: int a[][]第25行: &a[i][j]第38行: i==j && i+j==n-1第42行: sum

3、【单选题】输入某班学生某门课的成绩(最多不超过40人),当输入为负值时,表示输入结束,用函数编程统计成绩高于平均分的学生人数。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 40 int Average(int score[], int n); int ReadScore(int score[]); int GetAboveAver(int score[], int n); int main() { int score[N], m, n; n = ReadScore(score); /* 输入成绩,返回学生人数 */ printf(Total students are %d\n, n); m = GetAboveAver(score, n); /* 统计成绩在平均分及其上的学生人数 */ if (______________) printf(Students of above average is %d\n, m); return 0; } /* 函数功能:若n0,则计算并返回n个学生成绩的平均分,否则返回-1 */ int Average(int score[], int n) { int i, sum = 0; for (i=0; in; i++) { sum += score[i]; } return ______________; } /* 函数功能:输入学生某门课成绩,当输入成绩为负值时,结束输入,返回学生人数 */ int ReadScore(int score[]) { int i = -1; do{ i++; printf(Input score:); scanf(%d, score[i]); }while (__________); return _______; } /* 函数功能:若n0,则统计并返回成绩在平均分及平均分之上的学生人数,否则返回-1 */ int GetAboveAver(int score[], int n) { int i, count = 0, aver; aver = ______________; /* 计算并打印平均分 */ if (aver == -1) return -1; printf(Average score is %d\n, aver); for (i=0; in; i++) { if (score[i] = aver) count++; } return __________; }

A、第12行: m != -1第24行: n>0 ? sum/n : -1第35行: score[i] >= 0第36行: i第43行: Average(score, n)第50行: count

B、第12行: m == -1第24行: n>0 ? sum/n : -1第35行: score[i] >= 0第36行: i第43行: Average(score, n)第50行: i

C、第12行: m != -1第24行: n>0 ? -1 : sum/n第35行: score[i] >= 0第36行: i第43行: Average(n,score)第50行: count

D、第12行: m == -1第24行: n<=0 ? sum/n : -1第35行: score[i] >= 0第36行: score第43行: Average(score, n)第50行: aver

4、【单选题】模拟骰子的6000次投掷,编程统计并输出骰子的6个面各自出现的概率。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include _________ #include time.h #include stdio.h int main() { int face, roll, frequency[7] = {0}; srand(time (NULL)); for (roll=1; roll=6000; roll++) { face = _____________; __________________; } printf(%4s%17s\n, Face, Frequency); for (face=1; face=6; face++) { printf(%4d%17d\n, face, frequency[face]); } return 0; }

A、第1行: <stdlib.h>第11行: rand()%6 + 1第12行: frequency[face]++

B、第1行: <math.h>第11行: rand()/6 + 1第12行: frequency[face]++

C、第1行: <stdlib.h>第11行: rand()%6 + 1第12行: frequency[roll]++

D、第1行: <math.h>第11行: rand()/6 + 1第12行: frequency[roll]++

5、【单选题】以下程序中函数Fun的功能是对b所指数组中的第m至第n个数据取累加和,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h Fun(________,int m,int n) { int i,s=0; for( ______;in;i++) s=s+b[i]; return _______; } int main() { int x,a[]={1,2,3,4,5,6,7,8,9}; x=Fun(a,3,7); printf(%d\n,x); return 0; }

A、第2行: int b[]第5行: i=m-1第7行: s

B、第2行: int b[]第5行: i=1第7行: i

C、第2行: int b第5行: i=0第7行: s

D、第2行: int b[]第5行: i=n-1第7行: b[i]

6、【单选题】下面代码的功能是将数组a中存放的5个整型数据逆序后在屏幕上输出,具体输出内容如下:5 4 3 2 1按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include stdio.h void Fun(int b[],int i,int j) { int t; if(ij) { _________; b[i]=b[j]; _________; Fun(b,i+1,j-1); } } int main( ) { int i,a[5]={1,2,3,4,5}; _________; for(i=0;i5;i++) printf(%d\t,a[i]); printf(\n); return 0; }

A、第7行: t=b[i]第10行: b[j]=t第19行: Fun(a,0,4)

B、第7行: t=b[i]第10行: b[i]=t第19行: Fun(a,0,5)

C、第7行: t=b[j]第10行: b[j]=t第19行: Fun(a,1,4)

D、第7行: t=b[i]第10行: b[i]=t第19行: Fun(a,1,5)

7、【单选题】某人有5张2分的邮票和5张3分的邮票,问使用这些邮票可以组合出多少种不同面值的邮资。(例如:1张2分邮票加1张3分邮票可以组成5分的邮资;3张2分的邮票或2张3分的邮票都可以组成同样的6分邮资。)按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int i,j,k,s,n=0; int a[100]={0}; for(i=0;_________;i++) for(j=0;________;j++) { s=_____________; for(k=0;a[k]!=0;k++) if(s==a[k]) _________; if(a[k]==0 s0) { _________; n++; } } printf(\n %d kinds:,n); for(k=0;a[k];k++) printf(%2d,,a[k]); return 0; }

A、第7行: i<=5第8行: j<=5第10行: 2*i+3*j第14行: break第18行: a[k]=s

B、第7行: i<5第8行: j<5第10行: 2*i+3*j第14行: break第18行: s=a[k]

C、第7行: i<=5第8行: j<=5第10行: 2i+3j第14行: continue第18行: a[k]=s

D、第7行: i<5第8行: j<5第10行: 2*i+3*j第14行: continue第18行: s=a[k]+1

8、【单选题】以下程序中函数Sort的功能是对a所指数组中的数据进行由大到小的排序,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Sort(int a[],int n) { int i,j,t; for(i=0;_________;i++) for(________;jn;j++) if(a[i]a[j]) { t=a[i]; __________; a[j]=t; } } int main() { int aa[10]={1,2,30,4,5,6,7,8,9,10},i; __________; for(i=0;i10;i++) printf(%d,,aa[i]); printf(\n); return 0; }

A、第5行: i<n-1第6行: j=i+1第10行: a[i]=a[j]第18行: Sort(aa,10)

B、第5行: i<n-1第6行: j=i第10行: a[i]=a[j]第18行: Sort(aa[],10)

C、第5行: i<n第6行: j=i+1第10行: a[j]=a[i]第18行: Sort(aa,10)

D、第5行: i<=nj第6行: =i第10行: a[i]=a[j]第18行: Sort(10,aa)

9、【单选题】以下程序的功能是:按顺序读入10名学生4门课程的成绩,计算出每位学生的平均分并输出。程序运行后结果不正确,调试中发现有一条语句出现在程序中的位置不正确。这条语句是#include stdio.h int main() { int n,k; float score ,sum,ave; sum=0.0; for(n=1;n=10;n++) { for(k=1;k=4;k++) { scanf(%f,score); sum+=score; } ave=sum/4.0; printf(NO%d:%f\n,n,ave); } return 0; }

A、sum=0.0;

B、sum+=score;

C、ave=sun/4.0;

D、printf("NO%d:%f\n",n,ave);

10、【单选题】下面代码的功能是在屏幕上输出以下内容013程序中空白处缺少的代码由下列选项给出,其中有一个不能满足题目要求,请将其找出。#include stdio.h int main() { int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=0; for(i=0;i3;i++) for(j=i;j=i;j++) { t=t+____________; printf(%d\n,t); } return 0; }

A、b[j][t]

B、b[i][b[j][j]]

C、b[t][j]

D、b[i][j]

11、【单选题】以下程序的输出结果是void swap1(int c[]) { int t; t=c[0]; c[0]=c[1]; c[1]=t; } void swap2(int c0,int c1) { int t; t=c0; c0=c1; c1=t; } int main( ) { int a[2]={3,5},b[2]={3,5}; swap1(a); swap2(b[0],b[1]); printf(%d %d %d %d\n,a[0],a[1],b[0],b[1]); return 0; }

A、5 3 3 5

B、5 3 5 3

C、3 5 3 5

D、3 5 5 3

12、【单选题】以下程序中函数Reverse的功能是对数组a中的前一半元素逆序、后一半元素逆序,再将逆序后的前、后两部分数据位置交换。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。例如:主程序中数组b中的元素为{16,22,13,41,50,62,27,18,9,10},调用函数Reverse后,数组b中元素变为{10 9 18 27 62 50 41 13 22 16}#include stdio.h void Reverse(int a[],int n) { int i,t; for(i=0;________;i++) { t=a[i]; __________; a[n-i]=t; } } int main() { int b[10]={16,22,13,41,50,62,27,18,9,10}; int i,s=0; __________; for(i=0;i10;i++) { printf(%4d,b[i]); } return 0; }

A、第5行: i<=n/2第8行: a[i]=a[n-i]第17行: Reverse(b,9)

B、第5行: i<=n第8行: a[n-i]=a[i]第17行: Reverse(b,9)

C、第5行: i<=n/2第8行: a[n]=a[i]第17行: Reverse(9,b)

D、第5行: i<=n/2第8行: a[i]=a[n]第17行: Reverse(b,9)

13、【单选题】某矩阵m存储的数据如下:1 4 72 5 83 6 9现将该矩阵最后一行的所有数据输出到屏幕,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int m[][3]={1,4,7,2,5,8,3,6,9}; int i,j,k=____; for(i=0;_______;i++) { printf(%d,_________); } return 0; }

A、第5行: 2第7行: i<3第9行: m[k][i]

B、第5行: 3第7行: i<=3第9行: m[k][i]

C、第5行: 2第7行: i<2第9行: m[i][k]

D、第5行: 3第7行: i<3第9行: m[i][k]

14、【单选题】下列说法正确的是

A、在C语言中,数组的下标都是从0开始的。

B、在C语言中,不带下标的数组名代表数组的首地址,即第一个元素在内存中的地址。

C、简单变量做函数参数时,是将实参的值传给形参,实参和形参在内存中占用不同的存储单元,因此形参值的改变不会影响实参。

D、数组做函数参数时,是将实参数组的首地址传给形参,形参数组和实参数组在内存中共享相同的存储单元,因此对形参数组元素值的修改也就相当于是对实参数组元素值的修改。

E、在声明函数的一维数组形参时,通常不指定数组的大小,而用另一个形参来指定数组的大小。

F、C语言中的二维数组在内存中是按列存储的。

G、可以按任意的顺序对二维数组元素进行赋值,并且也可以按任意的屏幕输出顺序来输出二维数组元素。

H、在声明函数的二维数组形参时,可省略数组第二维的长度,但不能省略数组第一维的长度。

I、定义数组的大小、访问数组元素时在下标中都可以使用变量或表达式。

15、【单选题】用函数编程计算并输出如图所示的杨辉三角形。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#includestdio.h #define N 20 void CaculateYH(int a[][N], int n); void PrintYH(int a[][N], int n); int main() { int a[N][N] = {0}, n; printf(Input n(n20):); scanf(%d, n); CaculateYH(a, n); PrintYH(a, n); return 0; } /* 函数功能:计算杨辉三角形前n行元素的值 */ void CaculateYH(__________, int n) { int i, j; for (i=0; in; i++) { a[i][0] = 1; ___________; } for (_______; in; i++) { for (j=1; j=i-1; j++) { a[i][j] = __________________; } } } /* 函数功能:输出杨辉三角形前n行元素的值 */ void PrintYH(int a[][N], int n) { int i, j; for (i=0; in; i++) { for (j=0; _________; j++) { printf(%4d, a[i][j]); } printf(\n); } }

A、第16行: int a[][N]第22行: a[i][i] = 1第24行: i=2第28行: a[i-1][j-1] + a[i-1][j]第38行: j<=i

B、第16行: int a[][]第22行: a[i][i] = 1第24行: i=1第28行: a[i-1][j-1] + a[i-1][j]第38行: j<=i

C、第16行: int a[][N]第22行: a[0][i] = 1第24行: i=2第28行: a[i-1][j-1] + a[i-1][j]第38行: j<i

D、第16行: int a[N][]第22行: a[i][i] = 1第24行: i=2第28行: a[j-1][i-1] + a[j][i-1]第38行: j<=i

16、【单选题】假设有40个学生被邀请来给餐厅的饮食和服务质量打分,分数划分为1~10这10个等级(1表示最低分,10表示最高分),编程统计并按如下格式输出餐饮服务质量调查结果。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define M 40 #define N 11 int main() { int i, j, grade, feedback[M], count[N] = {0}; printf(Input the feedbacks of 40 students:\n); for (i=0; iM; i++) { scanf(%d, feedback[i]); } for (i=0; iM; i++) { _____________; } printf(Feedback\tCount\tHistogram\n); for (_________; grade=N-1; grade++) { printf(%8d\t%5d\t, grade, count[grade]); for (j=0; ___________; j++) { printf(%c,'*'); } printf(\n); } return 0; }

A、第16行: count[feedback[i]]++第21行: grade=1第24行: j<count[grade]

B、第16行: feedback[i]++第21行: grade=1第24行: j<N-1

C、第16行: count[i]++第21行: grade=0第24行: j<N-1

D、第16行: count[feedback[i]]++第21行: grade=0第24行: j<grade

练兵区——单选题——不计入总分

1、【单选题】假设有40个学生被邀请来给餐厅的饮食和服务质量打分,分数划分为1~10这10个等级(1表示最低分,10表示最高分),编程统计并按如下格式输出餐饮服务质量调查结果。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define M 40 #define N 11 int main() { int i, j, grade, feedback[M], count[N] = {0}; printf(Input the feedbacks of 40 students:\n); for (i=0; iM; i++) { scanf(%d, feedback[i]); } for (i=0; iM; i++) { _____________; } printf(Feedback\tCount\tHistogram\n); for (_________; grade=N-1; grade++) { printf(%8d\t%5d\t, grade, count[grade]); for (j=0; ___________; j++) { printf(%c,'*'); } printf(\n); } return 0; }

A、第16行: count[feedback[i]]++第21行: grade=1第24行: j<count[grade]

B、第16行: feedback[i]++第21行: grade=1第24行: j<N-1

C、第16行: count[i]++第21行: grade=0第24行: j<N-1

D、第16行: count[feedback[i]]++第21行: grade=0第24行: j<grade

2、【单选题】输入某班学生某门课的成绩(最多不超过40人,具体人数由用户键盘输入),用函数编程统计不及格人数。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 40 intGetFailNum(int score[], int n); int main() { int i, n, fail, score[N]; printf(How many students?); scanf(%d, n); for (i=0; in; i++) { scanf(%d, _________); } fail = _____________; printf(Fail students = %d\n, fail); return 0; } /* 函数功能:统计不及格人数 */ int GetFailNum(int score[], int n) { int i, count = 0; for (i=0; in; i++) { if (_________) count++; } return count; }

A、第11行: &score[i]第13行: GetFailNum(score, n)第23行: score[i] < 60

B、第11行: score[i]第13行: GetFailNum(score, n)第23行: score[i] <= 60

C、第11行: score[i]第13行: GetFailNum(n,score)第23行: score[i] < 60

D、第11行: &score[i]第13行: GetFailNum(score[i], n)第23行: score[i] >= 60

3、【单选题】模拟骰子的6000次投掷,编程统计并输出骰子的6个面各自出现的概率。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include _________ #include time.h #include stdio.h int main() { int face, roll, frequency[7] = {0}; srand(time (NULL)); for (roll=1; roll=6000; roll++) { face = _____________; __________________; } printf(%4s%17s\n, Face, Frequency); for (face=1; face=6; face++) { printf(%4d%17d\n, face, frequency[face]); } return 0; }

A、第1行: <stdlib.h>第11行: rand()%6 + 1第12行: frequency[face]++

B、第1行: <math.h>第11行: rand()/6 + 1第12行: frequency[face]++

C、第1行: <stdlib.h>第11行: rand()%6 + 1第12行: frequency[roll]++

D、第1行: <math.h>第11行: rand()/6 + 1第12行: frequency[roll]++

4、【单选题】以下程序中函数Fun的功能是对b所指数组中的第m至第n个数据取累加和,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h Fun(________,int m,int n) { int i,s=0; for( ______;i=n;i++) s=s+b[i]; return _______; } int main() { int x,a[]={1,2,3,4,5,6,7,8,9}; x=Fun(a,3,7); printf(%d\n,x); return 0; }

A、第2行: int b[]第5行: i=m第7行: s

B、第2行: int b[]第5行: i=1第7行: i

C、第2行: int b第5行: i=0第7行: s

D、第2行: int b[]第5行: i=n-1第7行: b[i]

5、【单选题】以下程序中函数Sort的功能是对a所指数组中的数据进行由大到小的排序,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Sort(int a[],int n) { int i,j,t; for(i=0;_________;i++) for(________;jn;j++) if(a[i]a[j]) { t=a[i]; __________; a[j]=t; } } int main() { int aa[10]={1,2,30,4,5,6,7,8,9,10},i; __________; for(i=0;i10;i++) printf(%d,,aa[i]); printf(\n); return 0;

A、第5行: i<n-1第6行: j=i+1第10行: a[i]=a[j]第18行: Sort(aa,10)

B、第5行: i<n-1第6行: j=i第10行: a[i]=a[j]第18行: Sort(aa[],10)

C、第5行: i<n第6行: j=i+1第10行: a[j]=a[i]第18行: Sort(aa,10)

D、第5行: i<=nj第6行: =i第10行: a[i]=a[j]第18行: Sort(10,aa)

6、【单选题】以下程序的功能是:按顺序读入10名学生4门课程的成绩,计算出每位学生的平均分并输出。程序运行后结果不正确,调试中发现有一条语句出现在程序中的位置不正确。这条语句是#include stdio.h int main() { int n,k; float score ,sum,ave; sum=0.0; for(n=1;n=10;n++) { for(k=1;k=4;k++) { scanf(%f,score); sum+=score; } ave=sum/4.0; printf(NO%d:%f\n,n,ave); } return 0;

A、sum=0.0;

B、sum+=score;

C、ave=sun/4.0;

D、printf("NO%d:%f\n",n,ave);

7、【单选题】以下程序中函数Reverse的功能是对数组a中的前一半元素逆序、后一半元素逆序,再将逆序后的前、后两部分数据位置交换。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。例如:主程序中数组b中的元素为{16,22,13,41,50,62,27,18,9,10},调用函数Reverse后,数组b中元素变为{10 9 18 27 62 50 41 13 22 16}#include stdio.h void Reverse(int a[],int n) { int i,t; for(i=0;________;i++) { t=a[i]; __________; a[n-i]=t; } } int main() { int b[10]={16,22,13,41,50,62,27,18,9,10}; int i,s=0; __________; for(i=0;i10;i++) { printf(%4d,b[i]); } return 0; }

A、第5行: i<=n/2第8行: a[i]=a[n-i]第17行: Reverse(b,9)

B、第5行: i<=n第8行: a[n-i]=a[i]第17行: Reverse(b,9)

C、第5行: i<=n/2第8行: a[n]=a[i]第17行: Reverse(9,b)

D、第5行: i<=n/2第8行: a[i]=a[n]第17行: Reverse(b,9)

8、【单选题】输入n×n阶矩阵,用函数编程计算并输出其两条对角线上的各元素之和。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 10 void InputMatrix(int a[N][N], int n); int AddDiagonal(int a[N][N], int n); int main() { int a[N][N], n, sum; printf(Input n:); scanf(%d, n); InputMatrix(a, n); sum = AddDiagonal(a, n); printf(sum = %d\n, sum); return 0; } /* 函数功能: 输入n×n矩阵的元素值,存于数组a中 */ void InputMatrix(___________, int n) { int i, j; printf(Input %d*%d matrix:\n, n, n); for (i=0; in; i++) { for (j=0; jn; j++) { scanf(%d,___________); } } } /* 函数功能: 计算n×n矩阵中两条对角线上的元素之和 */ int AddDiagonal(int a[N][N], int n) { int i, j, sum = 0; for (i=0; in; i++) { for (j=0; jn; j++) { if (________________) sum = sum + a[i][j]; } } return ____________; }

A、第17行: int a[N][N]第25行: &a[i][j]第38行: i==j || i+j==n-1第42行: sum

B、第17行: int a[N][N]第25行: &a[i][j]第38行: i==j && i+j==n-1第42行: a[i][j]

C、第17行: int a[N][N]第25行: a[i][j]第38行: i==j || i+j==n-1第42行: a[N][N]

D、第17行: int a[][]第25行: &a[i][j]第38行: i==j && i+j==n-1第42行: sum

9、【单选题】下面代码的功能是将数组a中存放的5个整型数据逆序后在屏幕上输出,具体输出内容如下:5 4 3 2 1按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Fun(int b[],int i,int j) { int t; if(ij) { _________; b[i]=b[j]; _________; Fun(b,i+1,j-1); } } int main( ) { int i,a[5]={1,2,3,4,5}; _________; for(i=0;i5;i++) printf(%d\t,a[i]); printf(\n); return 0; }

A、第7行: t=b[i]第10行: b[j]=t第19行: Fun(a,0,4)

B、第7行: t=b[i]第10行: b[i]=t第19行: Fun(a,0,5)

C、第7行: t=b[j]第10行: b[j]=t第19行: Fun(a,1,4)

D、第7行: t=b[i]第10行: b[i]=t第19行: Fun(a,1,5)

10、【单选题】某人有5张2分的邮票和5张3分的邮票,问使用这些邮票可以组合出多少种不同面值的邮资。(例如:1张2分邮票加1张3分邮票可以组成5分的邮资;3张2分的邮票或2张3分的邮票都可以组成同样的6分邮资。)按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int i,j,k,s,n=0; int a[100]={0}; for(i=0;_________;i++) for(j=0;________;j++) { s=_____________; for(for(k=0;a[k]!=0;k++)) if(s==a[k]) _________; if(a[k]==0s0) { _________; n++; } } printf(\n %d kinds:,n); for(k=0;a[k];k++) printf(%2d,,a[k]); return 0;

A、第7行: i<=5第8行: j<=5第10行: 2*i+3*j第14行: break第18行: a[k]=s

B、第7行: i<5第8行: j<5第10行: 2*i+3*j第14行: break第18行: s=a[k]

C、第7行: i<=5第8行: j<=5第10行: 2i+3j第14行: continue第18行: a[k]=s

D、第7行: i<5第8行: j<5第10行: 2*i+3*j第14行: continue第18行: s=a[k]+1

11、【单选题】某矩阵m存储的数据如下:1 4 72 5 83 6 9现将该矩阵最后一行的所有数据输出到屏幕,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { int m[][3]={1,4,7,2,5,8,3,6,9}; int i,j,k=____; for(i=0;_______;i++) { printf(%d,_________); } return 0; }

A、第5行: 2第7行: i<3第9行: m[k][i]

B、第5行: 3第7行: i<=3第9行: m[k][i]

C、第5行: 2第7行: i<2第9行: m[i][k]

D、第5行: 3第7行: i<3第9行: m[i][k]

12、【单选题】下列说法正确的是

A、在C语言中,数组的下标都是从0开始的。

B、在C语言中,不带下标的数组名代表数组的首地址,即第一个元素在内存中的地址。

C、简单变量做函数参数时,是将实参的值传给形参,实参和形参在内存中占用不同的存储单元,因此形参值的改变不会影响实参。

D、数组做函数参数时,是将实参数组的首地址传给形参,形参数组和实参数组在内存中共享相同的存储单元,因此对形参数组元素值的修改也就相当于是对实参数组元素值的修改。

E、在声明函数的一维数组形参时,通常不指定数组的大小,而用另一个形参来指定数组的大小。

F、C语言中的二维数组在内存中是按列存储的。

G、对于一个二维数组,可以按任意的顺序对其进行赋值,输出二维数组元素也可以按任意的顺序来输出。

H、在声明函数的二维数组形参时,可省略数组第二维的长度,但不能省略数组第一维的长度。

I、定义数组的大小、访问数组元素时在下标中都可以使用变量或表达式。

13、【单选题】用函数编程计算并输出如图所示的杨辉三角形。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#includestdio.h #define N 20 void CaculateYH(int a[][N], int n); void PrintYH(int a[][N], int n); int main() { int a[N][N] = {0}, n; printf(Input n(n20):); scanf(%d, n); CaculateYH(a, n); PrintYH(a, n); return 0; } /* 函数功能:计算杨辉三角形前n行元素的值 */ void CaculateYH(__________, int n) { int i, j; for (i=0; in; i++) { a[i][0] = 1; ___________; } for (_______; in; i++) { for (j=1; j=i-1; j++) { a[i][j] = __________________; } } } /* 函数功能:输出杨辉三角形前n行元素的值 */ void PrintYH(int a[][N], int n) { int i, j; for (i=0; in; i++) { for (j=0; _________; j++) { printf(%4d, a[i][j]); } printf(\n); } }

A、第16行: int a[][N]第22行: a[i][i] = 1第24行: i=2第28行: a[i-1][j-1] + a[i-1][j]第38行: j<=i

B、第16行: int a[][]第22行: a[i][i] = 1第24行: i=1第28行: a[i-1][j-1] + a[i-1][j]第38行: j<=i

C、第16行: int a[][N]第22行: a[0][i] = 1第24行: i=2第28行: a[i-1][j-1] + a[i-1][j]第38行: j<i

D、第16行: int a[N][]第22行: a[i][i] = 1第24行: i=2第28行: a[j-1][i-1] + a[j][i-1]第38行: j<=i

14、【单选题】输入某班学生某门课的成绩(最多不超过40人),当输入为负值时,表示输入结束,用函数编程统计成绩高于平均分的学生人数。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define N 40 int Average(int score[], int n); int ReadScore(int score[]); int GetAboveAver(int score[], int n); int main() { int score[N], m, n; n = ReadScore(score); /* 输入成绩,返回学生人数 */ printf(Total students are %d\n, n); m = GetAboveAver(score, n); /* 统计成绩在平均分及其上的学生人数 */ if (______________) printf(Students of above average is %d\n, m); return 0; } /* 函数功能:若n0,则计算并返回n个学生成绩的平均分,否则返回-1 */ int Average(int score[], int n) { int i, sum = 0; for (i=0; in; i++) { sum += score[i]; } return ______________; } /* 函数功能:输入学生某门课成绩,当输入成绩为负值时,结束输入,返回学生人数 */ int ReadScore(int score[]) { int i = -1; do{ i++; printf(Input score:); scanf(%d, score[i]); }while (__________); return _______; } /* 函数功能:若n0,则统计并返回成绩在平均分及平均分之上的学生人数,否则返回-1 */ int GetAboveAver(int score[], int n) { int i, count = 0, aver; aver = ______________; /* 计算并打印平均分 */ if (aver == -1) return -1; printf(Average score is %d\n, aver); for (i=0; in; i++) { if (score[i] = aver) count++; } return __________; }

A、第12行: m != -1第24行: n>0 ? sum/n : -1第35行: score[i] >= 0第36行: i第43行: Average(score, n)第50行: count

B、第12行: m == -1第24行: n>0 ? sum/n : -1第35行: score[i] >= 0第36行: i第43行: Average(score, n)第50行: i

C、第12行: m != -1第24行: n>0 ? -1 : sum/n第35行: score[i] >= 0第36行: i第43行: Average(n,score)第50行: count

D、第12行: m == -1第24行: n<=0 ? sum/n : -1第35行: score[i] >= 0第36行: score第43行: Average(score, n)第50行: aver

15、【单选题】下面代码的功能是在屏幕上输出以下内容013程序中空白处缺少的代码由下列选项给出,其中有一个不能满足题目要求,请将其找出。#include stdio.h int main() { int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=0; for(i=0;i3;i++) for(j=i;j=i;j++) { t=t+____________; printf(%d\n,t); } return 0; }

A、b[j][t]

B、b[i][b[j][j]]

C、b[t][j]

D、b[i][j]

16、【单选题】以下程序的输出结果是void swap1(int c[]) { int t; t=c[0]; c[0]=c[1]; c[1]=t; } void swap2(int c0,int c1) { int t; t=c0; c0=c1; c1=t; } int main( ) { int a[2]={3,5},b[2]={3,5}; swap1(a); swap2(b[0],b[1]); printf(%d %d %d %d\n,a[0],a[1],b[0],b[1]); return 0; }

A、5 3 3 5

B、5 3 5 3

C、3 5 3 5

D、3 5 5 3

指针的概念

1、【单选题】下列说法错误的是()。

A、指针变量占用的内存单元字节数就是它所指向的变量所占用的内存单元字节数。

B、指针变量指向的数据的类型,称为指针的基类型。指针变量只能指向同一基类型的变量。

C、指针变量使用之前必须初始化,如果你不知道该用什么值对其进行初始化的话,那么就先用NULL对其进行初始化。使用未初始化的结果将是无法预知的。

D、通过间接寻址运算符引用指针变量指向的变量的值,称为指针的解引用。

指针变量做函数参数与普通变量做函数参数的区别

1、【判断题】普通变量做函数参数,是将实参值的一个副本传给形参,而指针变量做函数参数是将变量的地址值传给形参,因此你想要修改哪个变量的值,将这个变量的地址传给指针形参就好了。

A、正确

B、错误

函数指针的定义和初始化

1、【判断题】int (*f)(int, int);这条语句定义的是一个函数指针f,它可以指向一个有两个整型形参和整型返回值的函数。假设int Fun(int a, int b);那么必须用f=Fun();对f进行初始化,让其指向函数Fun()。

A、正确

B、错误

筛法求素数

1、【判断题】筛法求素数的核心操作就是在一个按a[2]=2,a[3]=3,......,a[N]=N初始化的数组中依次筛掉所有素数的倍数。

A、正确

B、错误

随机生成一个各位相异的4位数

1、【判断题】void MakeDigit(int a[]) { int i, j, temp; srand(time(NULL)); for (i=0; i10; i++) { a[i] = i; } for (i=0; i10; i++) { j = rand() % 10; temp = a[j]; a[j] = a[i]; a[i] = temp; } }这个方法其实就是模拟了洗牌的方法对一个有序的数组元素进行随机置乱。

A、正确

B、错误

字符串的表示与存储

1、【单选题】下列说法正确的是()。

A、用双引号括起的一串字符是字符串常量,系统自动为其添加空字符'\0'作为字符串的结束标志。

B、字符数组的最后一个元素必须是字符'0'才能表示一个字符串。

C、char *pStr = "Hello China";表示定义了一个指向字符串常量的字符指针变量。此时既可以修改pStr的值,也可以通过间接寻址的方法修改pStr指向的字符。

D、char *pStr;scanf("%s", pStr);这两条语句的作用就是将用户从键盘输入的字符串保存到字符指针变量pStr中。

字符串处理函数

1、【单选题】下列说法正确的是()。

A、strlen()计算的是包含'\0'在内的字符串的长度。

B、字符串不能使用赋值运算符整体复制,必须使用strcpy函数进行字符串的复制。strcpy(str2, str1);是将字符数组str2中的字符串复制到字符数组str1中。

C、strcat(str2, str1);是将字符数组str2中的字符串连接到字符数组str1中的字符串的末尾,str1中的字符串末尾的空字符'\0'将被覆盖。

D、字符串不能用关系运算符>,<,==直接比较大小,必须使用strcmp函数比较大小,当出现第一对不相等的字符时,就由这两个字符的ASCII码值的大小来决定其所在字符串的大小。

向函数传递字符串

1、【判断题】向函数传递字符串,既可以用字符数组做函数参数,也可以用字符指针做函数参数,这两种方式都是传引用调用,就是将字符串的首地址、而非字符串中的全部字符传给形参。

A、正确

B、错误

从函数返回字符串

1、【判断题】函数返回值的类型既可以是字符指针,也可以是字符数组。

A、正确

B、错误

第10周编程题在线测试

练兵区——编程题——不计入总分

第10周测验

1、【单选题】下面程序的功能是从键盘输入一个字符串,编程将其字符顺序颠倒后重新存放,并输出这个字符串。程序的运行结果如下:Input a string:abcdef↙The inversed string is:fedcba按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h void Inverse(char *pStr); int main() { char str[80]; printf(Input a string:\n); gets(str);//输入字符串 Inverse(str);//将存于str数组中的字符串逆序存放 printf(The inversed string is:\n); puts(str);//输出字符串 return 0; } void Inverse(char *pStr) { int len = 0; char temp; char *pStart = pStr;//指针变量pStart指向字符串的第一个字符 char *pEnd;//指针变量pEnd指向字符串的最后一个字符 for (; *pStart!='\0'; _________) //求出字符串长度 { len++; } for (pStart=pStr,___________; pStartpEnd; pStart++,pEnd--) { temp = _________; ________________; *pEnd = temp; } }

A、第21行: pStart++第25行: pEnd=pStr+len-1第27行: *pStart第28行: *pStart = *pEnd

B、第21行: *pStart++第25行: pEnd=pStr+len第27行: *pStart第28行: *pStart = *pEnd

C、第21行: pStart++第25行: pEnd=pStr+len-1第27行: pStart第28行: pStart = pEnd

D、第21行: *pStart++第25行: pEnd=pStr+len第27行: pStart第28行: pStart = pEnd

2、【单选题】Squeeze函数的功能是删除字符串s中所出现的与变量c相同的字符。例如,输入为:abcdef↙c↙输出为:abdef按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h void Squeeze(char *s, char c); int main() { char a[80], c, *s; s = a; gets(a); scanf(%c,c); Squeeze(s, c); printf(%s\n, s); return 0; } void Squeeze(char *s, char c) { int i, j; for (i = j = 0; s[i] != '\0'; i++) { if (__________) { __________; j++; } } _____________; /* 在字符串t2的末尾添加字符串结束标志 */ }

A、第20行: s[i] != c第22行: s[j] = s[i]第26行: s[j] = '\0'

B、第20行: s[i] == c第22行: s[j] = s[i]第26行: s[i] = '\0'

C、第20行: s[j] != c第22行: s[i] = s[j]第26行: s[j] = '\0'

D、第20行: s[j] == c第22行: s[j] = s[i]第26行: s[i] = '\0'

3、【单选题】以下程序中函数FindMinString的功能是返回形参指针s1和s2所指字符串中较小字符串的首地址。例如,若运行时依次输入三个字符串:123↙1223↙124↙输出结果为1223按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h char *FindMinString( _____________ ) { if(_____________) return(s1); else return(s2); } int main() { int i; char string[20], str[3][20]; for(i=0;i3;i++) { gets(str[i]); } strcpy(string,FindMinString(str[0],str[1])); /*对字符串进行复制*/ strcpy(string,___________________); printf(%s\n,string); return 0; }

A、第3行: char *s1, char *s2第5行: strcmp(s1,s2)<0第20行: FindMinString(string,str[2])

B、第3行: char s1, char s2第5行: s1<s2第20行: FindMinString(string,str[2])

C、第3行: char s1, char s2第5行: strcmp(s1,s2)>0第20行: FindMinString(str[0],str[2])

D、第3行: char *s1, char *s2第5行: s1>s2第20行: strcmp(str[1],str[2])

4、【单选题】子函数Move的功能是将某字符串中的第i个字符向左移动1位,覆盖第i-1个字符。下面程序通过多次调用Move函数,将字符数组b中存放的字符串依次左移3位,并在移动后的字符串末尾添上字符0补足。程序的运行结果为:234567890034567890004567890000按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Move( _________,int i) { a[i-1]=a[i]; } int main( ) { char b[11]={1234567890}; int i,j; for (j=0;j=2;j++) { for(i=1;b[i]!='\0';i++) { __________; printf(%c,b[i-1]); } _________; printf(%c\n,________); } return 0; }

A、第2行: char *a第15行: Move(b,i)第18行: b[i-1]='0'第19行: b[i-1]

B、第2行: char a第15行: Move(b,i)第18行: b[i-1]='\0'第19行: b[i-1]

C、第2行: char *a第15行: Move(b,i)第18行: b[i]='0'第19行: b[i]

D、第2行: char a第15行: Move(i,b)第18行: b[i]='\0'第19行: b[i]

5、【单选题】下面能正确进行字符串赋值操作的是

A、char *s=“ABCDE”;

B、char s[5]={“ABCDE”};

C、char s[5]={'A', 'B', 'C', 'D', 'E'};

D、char *s,scanf(“%s”,s);

6、【单选题】下列对字符串的定义中,错误的是

A、char str[7] = "FORTRAN";

B、char str[] = "FORTRAN";

C、char *str = "FORTRAN";

D、char str[] = {'F','O','R','T','R','A','N',0};

7、【单选题】已知:int *p(); 则p是

A、一个函数,该函数的返回值是指向int型的指针变量

B、指向int型的指针变量

C、int型的指针数组

D、一个指向函数的指针变量,该函数的返回值是int型

8、【单选题】下面函数Fun的功能是#include stdio.h #include string.h int Fun(char *ps) { char *p; p=ps; while(*p++); return (p-ps); } int main() { char *s; int a1,a2; s = hello; a1=Fun(s); a2=strlen(s); printf(%d,%d\n, a1,a2); return 0; }

A、以上三种说法都不对

B、比较两个字符串的大小

C、求字符串的长度

D、将串ps复制到串s中

9、【单选题】下面函数Fun的功能是void Fun(char *s1, char *s2){ while(*s2++=*s1++);}

A、串复制

B、求串长

C、串比较

D、串反向

10、【单选题】给出以下定义,则正确的叙述是char x[ ]= “abcedfg”;char y[ ]={ ‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’’, ‘g’ };

A、数组x 的长度大于数组y的长度

B、数组x 和数组y 等价

C、数组x 和数组y 的长度相同

D、数组x 的长度小于数组y的长度

11、【单选题】执行以下代码段后,输出的字符串是#include stdio.h #include string.h int main() { char s1[10],*s2=ab\0cdef; strcpy(s1,s2); puts(s1); ....... return 0; }

A、ab

B、cdef

C、ab\0cdef

D、内容不确定

12、【单选题】下面程序的功能是将字符数组中存放的字符串以多种书写形式输出,如“Program”,“PROGRAM”,以及逆序输出的字符串“margorp”等,程序的运行结果为:ProgramPROGRAMmargorp按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main(void) { int i = 0; char b[] = program; char *a = PROGRAM; printf(_____\n, *a, b + 1); /* 输出Program */ while (_________________) /* 输出PROGRAM */ { ___________; i++; } printf(\n); while (_____) /* 输出margorp */ { putchar (___________); } __________; return 0; }

A、第8行: %c%s第9行: *(a+i)!='\0'第11行: putchar(*(a + i))第15行: --i第17行: *(b + i)第19行: putchar (*(b + i))

B、第8行: %s%s第9行: (*a+i)!='\0'第11行: putchar(*a + i))第15行: i--第17行: *(b + i)第19行: putchar (*(b + i))

C、第8行: %c%s第9行: *(a+i)=='\0'第11行: putchar(*(a + i)) 第15行: --i第17行: *b + i第19行: putchar (*b + i))

D、第8行: %s%s第9行: (*a+i)=='\0'第11行: putchar(*a + i))第15行: i--第17行: *b + i第19行: putchar (*b + i)

13、【单选题】下面程序的功能是用字符指针变量作函数参数编程实现字符串连接函数strcat()的功能,将字符串srcStr连接到字符串dstStr的尾部。程序的运行结果如下:Please enter the source string:abcd↙Please enter the other string:efgh↙The concat is:abcdefgh按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void MyStrcat(char *dstStr, char *srcStr); int main() { char s[80]; //源字符串 char t[80]; //待连接字符串 printf(Please enter the source string: \n); gets(s); printf(Please enter the other string: ); gets(t); //输入字符串 MyStrcat(s, t); //将字符数组t中的字符串连到s的尾部 printf(The concat is:\n); puts(s); //输出连接后的字符串s return 0; } void MyStrcat(char *dstStr, char *srcStr) //用字符指针作为函数参数 { while (__________) { dstStr++; } while (*srcStr != '\0') //若srcStr所指字符不是字符串结束标志 { _________; //将srcStr所指字符复制到dstStr所指的存储单元中 srcStr++; //使srcStr指向下一个字符 dstStr++; //使dstStr指向下一个存储单元 } _____________; //在字符串dstStr的末尾添加一个字符串结束标志 }

A、第19行: *dstStr != '\0'第25行: *dstStr = * srcStr第29行: *dstStr = '\0'

B、第19行: dstStr != '\0'第25行: dstStr = srcStr第29行: *dstStr = '\0'

C、第19行: *dstStr == '\0'第25行: *dstStr = * srcStr第29行: *dstStr = '\n'

D、第19行: dstStr == '\0'第25行: dstStr = srcStr第29行: *dstStr = '\n'

14、【单选题】以下程序的功能是分别测量字符数组及数组中存放的字符串的长度,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main( ) { char a[]=abcdefg,b[10]=abcdefg; _________________________; /*测量字符数组a,b的长度,并输出*/ _________________________; /*测量字符数组a,b中存放的字符串的长度,并输出*/ return 0; }

A、第6行: printf("%d %d\n",sizeof(a) ,sizeof(b))第7行: printf("%d %d\n",strlen(a) ,strlen(b))

B、第6行: printf("%d %d\n",strlen(a) ,strlen(b))第7行: printf("%d %d\n",sizeof(a) ,sizeof(b))

C、第6行: printf("%d %d\n",sizeof(*a) ,sizeof(*b))第7行: printf("%d %d\n",strlen(*a) ,strlen(*b))

D、第6行: printf("%d %d\n",sizeof(&a) ,sizeof(&b))第7行: printf("%d %d\n",strlen(&a) ,strlen(&b))

15、【单选题】下面程序的功能是将一个字符串s2插入到字符串s1中,其起始插入位置为n。程序运行示例如下:main string:hello,world!sub string:cc site of begining:(=12)5After instert:hellocc,world!按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 100 int main() { int n, i, j, k, len; char s1[N], s2[N], s3[2 * N]; printf(main string:); gets(s1); printf(sub string:); gets(s2); len = strlen(s1); do { printf(site of begining:(=%d), len); scanf(%d, n); }while (__________); for (i = 0; i n; i++) { s3[i] = s1[i]; } for (j = 0; s2[j] != '\0'; j++) { __________________; } for (________; s1[k] != '\0'; k++) { ________________; } s3[j + k] = '\0'; printf(After instert:%s\n, s3); return 0; }

A、第17行: n > len第25行: s3[i + j] = s2[j]第27行: k = n第29行: s3[j + k] = s1[k]

B、第17行: n < len第25行: s3[i] = s2[j]第27行: k = n第29行: s3[j] = s1[k]

C、第17行: n <= len第25行: s2[j]=s3[i + j] 第27行: k = 0第29行: s3[j] = s1[k]

D、第17行: n >= len第25行: s3[j] = s2[j]第27行: k = 0第29行: s1[k] = s3[j + k]

16、【单选题】下面程序的功能是从键盘输入一行字符(最长不超过80字符),用函数编程统计其中单词(以空格作为间隔符的字符串)的个数。基本思路是:当前被检验字符不是空格,而前一被检验字符是空格,则表示有新单词出现。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。(下面答案中两个单引号''中间都有一个空格)样例1:Input a string:How are you↙Numbers of words = 3样例2:Input a string: How are you↙Numbers of words = 3#include stdio.h int CountWords(char str[]); int main() { char str[81]; int num; printf(Input a string:\n); gets(str); num=CountWords(str); printf(Number of words=%d\n, num); return 0; } int CountWords(char str[]) { int i, num; num = (__________) ? 1 : 0; i=1; while (str[i]!='\0') { if (_______________________) { num++; } __________; } return num; }

A、第17行: str[0] != ' '第21行: str[i]!=' ' && str[i-1] == ' '第25行: i++

B、第17行: str[0] == ' '第21行: str[i]!=' ' || str[i-1] == ' '第25行: i++

C、第17行: str[0] != '\0 '第21行: str[i]==' ' && str[i-1] == ' '第25行: i++

D、第17行: str[0] != ' '第21行: str[i]!=' ' && str[i-1] != ' '第25行: num++

17、【单选题】下面程序的功能是实现字符串逆序存放。程序运行结果如下:Input a string:ABCDEFGHI↙Inversed results:IHGFEDCBA按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 80 void Inverse(char *pStr); int main() { char a[N]; printf(Input a string:); gets(a); Inverse(a); printf(Inversed results:%s\n, a); return 0; } /* 函数功能: 实现将字符数组中的字符串逆序存放 */ void Inverse(____________) { int len; char temp; char *pStart; /* 指针变量pStart指向字符串的第一个字符 */ char *pEnd; /* 指针变量pEnd指向字符串的最后一个字符 */ len = strlen(pStr); /* 求出字符串长度 */ for (pStart=pStr,___________; pStartpEnd; pStart++,__________) { temp = *pStart; ______________; *pEnd = temp; } }

A、第16行: char *pStr第23行: pEnd=pStr+len-1 pEnd--第26行: *pStart = *pEnd

B、第16行: char pStr第23行: pEnd=pStr+len pEnd--第26行: *pStart = *pEnd

C、第16行: char *pStr第23行: pEnd=pStr+len-1 pEnd++第26行: pStart = pEnd

D、第16行: char pStr第23行: pEnd=pStr+len+1 pEnd++第26行: *pStart = *pEnd

18、【单选题】下面程序的功能是从键盘输入一行字符(不超过80个),统计其中的英文字符、数字字符、空格和其他字符的个数。例如,输入的一行字符为*****c language.*****输出为English character: 9digit character: 0space: 1other character: 11按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define STR_LEN 80 int main() { char str[STR_LEN+1]; int len, i, letter = 0, digit = 0, space = 0, others = 0; printf(Please input a string:); ___________; for (i = 0; __________; i++) { if (___________________________) letter ++; /*统计英文字符 */ else if (______________________) digit ++; /*统计数字字符 */ else if (str[i] == ' ' ) space ++; /*统计空格*/ else others ++; /*统计其他字符的个数*/ } printf(English character: %d\n, letter); printf(digit character: %d\n, digit); printf(space: %d\n, space); printf(other character: %d\n, others); return 0; }

A、第9行: gets(str)第10行: str[i] != '\0'第12行: str[i] >= 'a' && str[i] <= 'z' || str[i] >= 'A' && str[i] <= 'Z'第14行: str[i] >= '0' && str[i] <= '9'

B、第9行: scanf("%s",str)第10行: str[i] != '\0'第12行: 'z' >= str[i] >= 'a' || 'A' <= str[i] <= 'Z'第14行: 9 >= str[i] >= 0

C、第9行: puts(str)第10行: str[i] != '\n'第12行: 'z' >= str[i] >= 'a' || 'A' <= str[i] <= 'Z'第14行: str[i] >= '0' && str[i] <= '9'

D、第9行: scanf("%s",str)第10行: str[i] != '\n'第12行: str[i] >= 'a' || str[i] <= 'z' && str[i] >= 'A' || str[i] <= 'Z'第14行: str[i] >= 0 && str[i] <= 9

19、【单选题】下面程序的功能是在字符串每个字符间插入一个空格。程序的运行结果如下:Input a string:Howareyou↙Insert results:H o w a r e y o u按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 100 void Insert(char s[]); int main() { char str[N]; printf(Input a string:); gets(str); Insert(str); printf(Insert results:%s\n, str); return 0; } void Insert(char s[]) { char t[N]; int i, j; ____________; for (i=0, j=0; ____________; i++, j++) { ________; j++; ________; } s[j] = '\0';/* 在字符串s的末尾添加字符串结束标志 */ }

A、第19行:strcpy(t, s)第20行:t[i]!='\0'第22行:s[j] = t[i]第24行:s[j] = ' '

B、第19行:t=s;第20行:t[i]!='\0'第22行:s[i] = t[j]第24行:s[j] = ' '

C、第19行:strcpy(t, s)第20行:t[i]='\0'第22行:t[j] = s[i]第24行:s[j] = '\0 '

D、第19行:strcpy(s, t)第20行:t[i]=='\0'第22行:s[j] = t[i]第24行:s[j] = '0 '

20、【单选题】子函数Change的功能是将英文大写字母转换为小写字母,下面程序的输出结果是 abc_abc_def按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Change(__________) { int i; for(;________;ch++) { if(____________) _________________; } } int main() { char s[]=ABC_abc_DEF; Change(s); printf(%s\n,s); return 0; }

A、第2行: char *ch第5行: *ch!='\0'第7行: *ch>='A'&& *ch<='Z'第8行: *ch=*ch-'A'+'a'

B、第2行: char ch第5行: ch!='\0'第7行: *ch>='A'&& *ch<='Z'第8行: *ch=*ch-'A'+'a'

C、第2行: char *ch第5行: *ch!='\0'第7行: ch>='A'&& ch<='Z'第8行: ch=ch-'A'+'a'

D、第2行: char ch[]第5行: *ch=='\0'第7行: *ch>='A'|| *ch<='Z'第8行: *ch=*ch-'A'+'a'

21、【单选题】下面程序的功能是比较用户键盘输入的口令userInput与内设的口令password是否相同。若相同,则输出Correct password! Welcome to the system...,若userInputpassword,则输出Invalid password!user inputpassword,否则输出Invalid password!user inputpassword。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main() { char password[7] = secret; char userInput[81] ; printf(Input Password:); scanf(_____________); if ( ______________ ) printf(Correct password! Welcome to the system...\n); else if ( ___________________) printf(Invalid password!user inputpassword\n); else printf(Invalid password!user inputpassword\n); return 0; }

A、第8行: "%s", userInput第9行: strcmp(userInput, password) == 0第11行: strcmp(userInput, password) < 0

B、第8行: "%c", userInput第9行: strcmp(userInput, password) = 0第11行: strcmp(userInput, password) < 0

C、第8行: "%s", userInput第9行: userInput==password第11行: userInput<password

D、第8行: "%c", userInput第9行: strcpy(userInput, password) == 0第11行: strcpy(userInput, password) < 0

22、【单选题】下列说法错误的是

A、字符数组的最后一个元素必须是字符'0'才能表示一个字符串。

B、char *pStr = "Hello China";表示定义了一个指向字符串常量的字符指针变量。此时既可以修改pStr的值,也可以通过间接寻址的方法修改pStr指向的字符。

C、char *pStr;scanf("%s", pStr);这两条语句的作用就是将用户从键盘输入的字符串保存到字符指针变量pStr中。

D、字符串不能用关系运算符>,<,==直接比较大小,必须使用strcmp函数比较大小,当出现第一对不相等的字符时,就由这两个字符的ASCII码值的大小来决定其所在字符串的大小。

E、用双引号括起的一串字符是字符串常量,系统自动为其添加空字符'\0'作为字符串的结束标志。

F、通过间接寻址运算符引用指针变量指向的变量的值,称为指针的解引用。

23、【单选题】下列说法正确的是

A、指针变量指向的数据的类型,称为指针的基类型。指针变量只能指向同一基类型的变量。

B、指针变量使用之前必须初始化,如果你不知道该用什么值对其进行初始化的话,那么就先用NULL对其进行初始化。使用未初始化的结果将是无法预知的。

C、指针变量占用的内存单元字节数就是它所指向的变量所占用的内存单元字节数。

D、strcat(str2, str1);是将字符数组str2中的字符串连接到字符数组str1中的字符串的末尾,str1中的字符串末尾的空字符'\0'将被覆盖。

E、字符串不能使用赋值运算符整体复制,必须使用strcpy函数进行字符串的复制。strcpy(str2, str1);是将字符数组str2中的字符串复制到字符数组str1中。

F、strlen()计算的是包含'\0'在内的字符串的长度。

练兵区——单选题——不计入总分

1、【单选题】下面能正确进行字符串赋值操作的是

A、char *s=“ABCDE”;

B、char s[5]={“ABCDE”};

C、char s[5]={'A', 'B', 'C', 'D', 'E'};

D、char *s,scanf(“%s”,s);

2、【单选题】已知:int *p(); 则p是

A、一个函数,该函数的返回值是指向int型的指针变量

B、指向int型的指针变量

C、int型的指针数组

D、一个指向函数的指针变量,该函数的返回值是int型

3、【单选题】给出以下定义,则正确的叙述是char x[ ]= “abcedfg”;char y[ ]={ ‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’’, ‘g’ };

A、数组x 的长度大于数组y的长度

B、数组x 和数组y 等价

C、数组x 和数组y 的长度相同

D、数组x 的长度小于数组y的长度

4、【单选题】下面程序的功能是用字符指针变量作函数参数编程实现字符串连接函数strcat()的功能,将字符串srcStr连接到字符串dstStr的尾部。程序的运行结果如下:Please enter the source string:abcd↙Please enter the other string:efgh↙The concat is:abcdefgh按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void MyStrcat(char *dstStr, char *srcStr); int main() { char s[80]; //源字符串 char t[80]; //待连接字符串 printf(Please enter the source string: \n); gets(s); printf(Please enter the other string: ); gets(t); //输入字符串 MyStrcat(s, t); //将字符数组t中的字符串连到s的尾部 printf(The concat is:\n); puts(s); //输出连接后的字符串s return 0; } void MyStrcat(char *dstStr, char *srcStr) //用字符指针作为函数参数 { while (__________) { dstStr++; } while (*srcStr != '\0') //若srcStr所指字符不是字符串结束标志 { _________; //将srcStr所指字符复制到dstStr所指的存储单元中 srcStr++; //使srcStr指向下一个字符 dstStr++; //使dstStr指向下一个存储单元 } _____________; //在字符串dstStr的末尾添加一个字符串结束标志 }

A、第19行: *dstStr != '\0'第25行: *dstStr = * srcStr第29行: *dstStr = '\0'

B、第19行: dstStr != '\0'第25行: dstStr = srcStr第29行: *dstStr = '\0'

C、第19行: *dstStr == '\0'第25行: *dstStr = * srcStr第29行: *dstStr = '\n'

D、第19行: dstStr == '\0'第25行: dstStr = srcStr第29行: *dstStr = '\n'

5、【单选题】以下程序中函数FindMinString的功能是返回形参指针s1和s2所指字符串中较小字符串的首地址。例如,若运行时依次输入三个字符串:123↙1223↙124↙输出结果为1223按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h char *FindMinString( _____________ ) { if(_____________) return(s1); else return(s2); } int main() { int i; char string[20], str[3][20]; for(i=0;i3;i++) { gets(str[i]); } strcpy(string,FindMinString(str[0],str[1])); /*对字符串进行复制*/ strcpy(string,___________________); printf(%s\n,string); return 0; }

A、第3行: char *s1, char *s2第5行: strcmp(s1,s2)<0第20行: FindMinString(string,str[2])

B、第3行: char s1, char s2第5行: s1<s2第20行: FindMinString(string,str[2])

C、第3行: char s1, char s2第5行: strcmp(s1,s2)>0第20行: FindMinString(str[0],str[2])

D、第3行: char *s1, char *s2第5行: s1>s2第20行: strcmp(str[1],str[2])

6、【单选题】子函数Move的功能是将某字符串中的第i个字符向左移动1位,覆盖第i-1个字符。下面程序通过多次调用Move函数,将字符数组b中存放的字符串依次左移3位,并在移动后的字符串末尾添上字符0补足。程序的运行结果为:234567890034567890004567890000按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Move( _________,int i) { a[i-1]=a[i]; } int main( ) { char b[11]={1234567890}; int i,j; for (j=0;j=2;j++) { for(i=1;b[i]!='\0';i++) { __________; printf(%c,b[i-1]); } _________; printf(%c\n,________); } return 0; }

A、第2行: char *a第15行: Move(b,i)第18行: b[i-1]='0'第19行: b[i-1]

B、第2行: char a第15行: Move(b,i)第18行: b[i-1]='\0'第19行: b[i-1]

C、第2行: char *a第15行: Move(b,i)第18行: b[i]='0'第19行: b[i]

D、第2行: char a第15行: Move(i,b)第18行: b[i]='\0'第19行: b[i]

7、【单选题】下面程序的功能是将字符数组中存放的字符串以多种书写形式输出,如“Program”,“PROGRAM”,以及逆序输出的字符串“margorp”等,程序的运行结果为:ProgramPROGRAMmargorp按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main(void) { int i = 0; char b[] = program; char *a = PROGRAM; printf(_____\n, *a, b + 1); /* 输出Program */ while (_________________) /* 输出PROGRAM */ { ___________; i++; } printf(\n); while (_____) /* 输出margorp */ { putchar (___________); } __________; return 0; }

A、第8行: %c%s第9行: *(a+i)!='\0'第11行: putchar(*(a + i))第15行: --i第17行: *(b + i)第19行: putchar (*(b + i))

B、第8行: %s%s第9行: (*a+i)!='\0'第11行: putchar(*a + i))第15行: i--第17行: *(b + i)第19行: putchar (*(b + i))

C、第8行: %c%s第9行: *(a+i)=='\0'第11行: putchar(*(a + i)) 第15行: --i第17行: *b + i第19行: putchar (*b + i))

D、第8行: %s%s第9行: (*a+i)=='\0'第11行: putchar(*a + i))第15行: i--第17行: *b + i第19行: putchar (*b + i)

8、【单选题】Squeeze函数的功能是删除字符串s中所出现的与变量c相同的字符。例如,输入为:abcdef↙c↙输出为:abdef按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h void Squeeze(char *s, char c); int main() { char a[80], c, *s; s = a; gets(a); scanf(%c,c); Squeeze(s, c); printf(%s\n, s); return 0; } void Squeeze(char *s, char c) { int i, j; for (i = j = 0; s[i] != '\0'; i++) { if (__________) { __________; j++; } } _____________; /* 在字符串t2的末尾添加字符串结束标志 */ }

A、第20行: s[i] != c第22行: s[j] = s[i]第26行: s[j] = '\0'

B、第20行: s[i] == c第22行: s[j] = s[i]第26行: s[i] = '\0'

C、第20行: s[j] != c第22行: s[i] = s[j]第26行: s[j] = '\0'

D、第20行: s[j] == c第22行: s[j] = s[i]第26行: s[i] = '\0'

9、【单选题】下列对字符串的定义中,错误的是

A、char str[7] = "FORTRAN";

B、char str[] = "FORTRAN";

C、char *str = "FORTRAN";

D、char str[] = {'F','O','R','T','R','A','N',0};

10、【单选题】下面函数Fun的功能是void Fun(char *s1, char *s2){ while(*s2++=*s1++);}

A、串复制

B、求串长

C、串比较

D、串反向

11、【单选题】执行以下代码段后,输出的字符串是#include stdio.h #include string.h int main() { char s1[10],*s2=ab\0cdef; strcpy(s1,s2); puts(s1); ....... return 0; }

A、ab

B、cdef

C、ab\0cdef

D、内容不确定

12、【单选题】下面程序的功能是从键盘输入一个字符串,编程将其字符顺序颠倒后重新存放,并输出这个字符串。程序的运行结果如下:Input a string:abcdef↙The inversed string is:fedcba按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h void Inverse(char *pStr); int main() { char str[80]; printf(Input a string:\n); gets(str);//输入字符串 Inverse(str);//将存于str数组中的字符串逆序存放 printf(The inversed string is:\n); puts(str);//输出字符串 return 0; } void Inverse(char *pStr) { int len = 0; char temp; char *pStart = pStr;//指针变量pStart指向字符串的第一个字符 char *pEnd;//指针变量pEnd指向字符串的最后一个字符 for (; *pStart!='\0'; _________) //求出字符串长度 { len++; } for (pStart=pStr,___________; pStartpEnd; pStart++,pEnd--) { temp = _________; ________________; *pEnd = temp; } }

A、第21行: pStart++第25行: pEnd=pStr+len-1第27行: *pStart第28行: *pStart = *pEnd

B、第21行: *pStart++第25行: pEnd=pStr+len第27行: *pStart第28行: *pStart = *pEnd

C、第21行: pStart++第25行: pEnd=pStr+len-1第27行: pStart第28行: pStart = pEnd

D、第21行: *pStart++第25行: pEnd=pStr+len第27行: pStart第28行: pStart = pEnd

13、【单选题】下面函数Fun的功能是#include stdio.h #include string.h int Fun(char *ps) { char *p; p=ps; while(*p++); return (p-ps); } int main() { char *s; int a1,a2; s = hello; a1=Fun(s); a2=strlen(s); printf(%d,%d\n, a1,a2); return 0; }

A、以上三种说法都不对

B、比较两个字符串的大小

C、求字符串的长度

D、将串ps复制到串s中

14、【单选题】下面程序的功能是从键盘输入一行字符(不超过80个),统计其中的英文字符、数字字符、空格和其他字符的个数。例如,输入的一行字符为*****c language.*****输出为English character: 9digit character: 0space: 1other character: 11按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define STR_LEN 80 int main() { char str[STR_LEN+1]; int len, i, letter = 0, digit = 0, space = 0, others = 0; printf(Please input a string:); ___________; for (i = 0; __________; i++) { if (___________________________) letter ++; /*统计英文字符 */ else if (______________________) digit ++; /*统计数字字符 */ else if (str[i] == ' ' ) space ++; /*统计空格*/ else others ++; /*统计其他字符的个数*/ } printf(English character: %d\n, letter); printf(digit character: %d\n, digit); printf(space: %d\n, space); printf(other character: %d\n, others); return 0; }

A、第9行: gets(str)第10行: str[i] != '\0'第12行: str[i] >= 'a' && str[i] <= 'z' || str[i] >= 'A' && str[i] <= 'Z'第14行: str[i] >= '0' && str[i] <= '9'

B、第9行: scanf("%s",str)第10行: str[i] != '\0'第12行: 'z' >= str[i] >= 'a' || 'A' <= str[i] <= 'Z'第14行: 9 >= str[i] >= 0

C、第9行: puts(str)第10行: str[i] != '\n'第12行: 'z' >= str[i] >= 'a' || 'A' <= str[i] <= 'Z'第14行: str[i] >= '0' && str[i] <= '9'

D、第9行: scanf("%s",str)第10行: str[i] != '\n'第12行: str[i] >= 'a' || str[i] <= 'z' && str[i] >= 'A' || str[i] <= 'Z'第14行: str[i] >= 0 && str[i] <= 9

15、【单选题】下面程序的功能是在字符串每个字符间插入一个空格。程序的运行结果如下:Input a string:Howareyou↙Insert results:H o w a r e y o u按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 100 void Insert(char s[]); int main() { char str[N]; printf(Input a string:); gets(str); Insert(str); printf(Insert results:%s\n, str); return 0; } void Insert(char s[]) { char t[N]; int i, j; ____________; for (i=0, j=0; ____________; i++, j++) { ________; j++; ________; } s[j] = '\0';/* 在字符串s的末尾添加字符串结束标志 */ }

A、第19行:strcpy(t, s)第20行:t[i]!='\0'第22行:s[j] = t[i]第24行:s[j] = ' '

B、第19行:t=s;第20行:t[i]!='\0'第22行:s[i] = t[j]第24行:s[j] = ' '

C、第19行:strcpy(t, s)第20行:t[i]='\0'第22行:t[j] = s[i]第24行:s[j] = '\0 '

D、第19行:strcpy(s, t)第20行:t[i]=='\0'第22行:s[j] = t[i]第24行:s[j] = '0 '

16、【单选题】下面程序的功能是实现字符串逆序存放。程序运行结果如下:Input a string:ABCDEFGHI↙Inversed results:IHGFEDCBA按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 80 void Inverse(char *pStr); int main() { char a[N]; printf(Input a string:); gets(a); Inverse(a); printf(Inversed results:%s\n, a); return 0; } /* 函数功能: 实现将字符数组中的字符串逆序存放 */ void Inverse(____________) { int len; char temp; char *pStart; /* 指针变量pStart指向字符串的第一个字符 */ char *pEnd; /* 指针变量pEnd指向字符串的最后一个字符 */ len = strlen(pStr); /* 求出字符串长度 */ for (pStart=pStr,___________; pStartpEnd; pStart++,__________) { temp = *pStart; ______________; *pEnd = temp; } }

A、第16行: char *pStr第23行: pEnd=pStr+len-1 pEnd--第26行: *pStart = *pEnd

B、第16行: char pStr第23行: pEnd=pStr+len pEnd--第26行: *pStart = *pEnd

C、第16行: char *pStr第23行: pEnd=pStr+len-1 pEnd++第26行: pStart = pEnd

D、第16行: char pStr第23行: pEnd=pStr+len+1 pEnd++第26行: *pStart = *pEnd

17、【单选题】子函数Change的功能是将英文大写字母转换为小写字母,下面程序的输出结果是 abc_abc_def按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h void Change(__________) { for(;________;ch++) { if(____________) _________________; } } int main() { char s[]=ABC_abc_DEF; Change(s); printf(%s\n,s); return 0; }

A、第2行: char *ch第5行: *ch!='\0'第7行: *ch>='A'&& *ch<='Z'第8行: *ch=*ch-'A'+'a'

B、第2行: char ch第5行: ch!='\0'第7行: *ch>='A'&& *ch<='Z'第8行: *ch=*ch-'A'+'a'

C、第2行: char *ch第5行: *ch!='\0'第7行: ch>='A'&& ch<='Z'第8行: ch=ch-'A'+'a'

D、第2行: char ch[]第5行: *ch=='\0'第7行: *ch>='A'|| *ch<='Z'第8行: *ch=*ch-'A'+'a'

18、【单选题】下面程序的功能是比较用户键盘输入的口令userInput与内设的口令password是否相同。若相同,则输出Correct password! Welcome to the system...,若userInputpassword,则输出Invalid password!user inputpassword,否则输出Invalid password!user inputpassword。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main() { char password[7] = secret; char userInput[81] ; printf(Input Password:); scanf(_____________); if ( ______________ ) printf(Correct password! Welcome to the system...\n); else if ( ___________________) printf(Invalid password!user inputpassword\n); else printf(Invalid password!user inputpassword\n); return 0; }

A、第8行: "%s", userInput第9行: strcmp(userInput, password) == 0第11行: strcmp(userInput, password) < 0

B、第8行: "%c", userInput第9行: strcmp(userInput, password) = 0第11行: strcmp(userInput, password) < 0

C、第8行: "%s", userInput第9行: userInput==password第11行: userInput<password

D、第8行: "%c", userInput第9行: strcpy(userInput, password) == 0第11行: strcpy(userInput, password) < 0

19、【单选题】下列说法正确的是

A、指针变量指向的数据的类型,称为指针的基类型。指针变量只能指向同一基类型的变量。

B、指针变量使用之前必须初始化,如果你不知道该用什么值对其进行初始化的话,那么就先用NULL对其进行初始化。使用未初始化的结果将是无法预知的。

C、指针变量占用的内存单元字节数就是它所指向的变量所占用的内存单元字节数。

D、strcat(str2, str1);是将字符数组str2中的字符串连接到字符数组str1中的字符串的末尾,str1中的字符串末尾的空字符'\0'将被覆盖。

E、字符串不能使用赋值运算符整体复制,必须使用strcpy函数进行字符串的复制。strcpy(str2, str1);是将字符数组str2中的字符串复制到字符数组str1中。

F、strlen()计算的是包含'\0'在内的字符串的长度。

20、【单选题】下列说法错误的是

A、字符数组的最后一个元素必须是字符'0'才能表示一个字符串。

B、char *pStr = "Hello China";表示定义了一个指向字符串常量的字符指针变量。此时既可以修改pStr的值,也可以通过间接寻址的方法修改pStr指向的字符。

C、char *pStr;scanf("%s", pStr);这两条语句的作用就是将用户从键盘输入的字符串保存到字符指针变量pStr中。

D、字符串不能用关系运算符>,<,==直接比较大小,必须使用strcmp函数比较大小,当出现第一对不相等的字符时,就由这两个字符的ASCII码值的大小来决定其所在字符串的大小。

E、用双引号括起的一串字符是字符串常量,系统自动为其添加空字符'\0'作为字符串的结束标志。

F、通过间接寻址运算符引用指针变量指向的变量的值,称为指针的解引用。

21、【单选题】以下程序的功能是分别测量字符数组及数组中存放的字符串的长度,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h int main( ) { char a[]=abcdefg,b[10]=abcdefg; _________________________; /*测量字符数组a,b的长度,并输出*/ _________________________; /*测量字符数组a,b中存放的字符串的长度,并输出*/ return 0; }

A、第6行: printf("%d %d\n",sizeof(a) ,sizeof(b))第7行: printf("%d %d\n",strlen(a) ,strlen(b))

B、第6行: printf("%d %d\n",strlen(a) ,strlen(b))第7行: printf("%d %d\n",sizeof(a) ,sizeof(b))

C、第6行: printf("%d %d\n",sizeof(*a) ,sizeof(*b))第7行: printf("%d %d\n",strlen(*a) ,strlen(*b))

D、第6行: printf("%d %d\n",sizeof(&a) ,sizeof(&b))第7行: printf("%d %d\n",strlen(&a) ,strlen(&b))

22、【单选题】下面程序的功能是将一个字符串s2插入到字符串s1中,其起始插入位置为n。程序运行示例如下:main string:hello,world!sub string:cc site of begining:(=12)5After instert:hellocc,world!按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #include string.h #define N 100 int main() { int n, i, j, k, len; char s1[N], s2[N], s3[2 * N]; printf(main string:); gets(s1); printf(sub string:); gets(s2); len = strlen(s1); do { printf(site of begining:(=%d), len); scanf(%d, n); }while (__________); for (i = 0; i n; i++) { s3[i] = s1[i]; } for (j = 0; s2[j] != '\0'; j++) { __________________; } for (________; s1[k] != '\0'; k++) { ________________; } s3[j + k] = '\0'; printf(After instert:%s\n, s3); return 0; }

A、第17行: n > len第25行: s3[i + j] = s2[j]第27行: k = n第29行: s3[j + k] = s1[k]

B、第17行: n < len第25行: s3[i] = s2[j]第27行: k = n第29行: s3[j] = s1[k]

C、第17行: n <= len第25行: s2[j]=s3[i + j] 第27行: k = 0第29行: s3[j] = s1[k]

D、第17行: n >= len第25行: s3[j] = s2[j]第27行: k = 0第29行: s1[k] = s3[j + k]

23、【单选题】下面程序的功能是从键盘输入一行字符(最长不超过80字符),用函数编程统计其中单词(以空格作为间隔符的字符串)的个数。基本思路是:当前被检验字符不是空格,而前一被检验字符是空格,则表示有新单词出现。按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。(下面答案中两个单引号''中间都有一个空格)样例1:Input a string:How are you↙Numbers of words = 3样例2:Input a string: How are you↙Numbers of words = 3#include stdio.h int CountWords(char str[]); int main() { char str[81]; int num; printf(Input a string:\n); gets(str); num=CountWords(str); printf(Number of words=%d\n, num); return 0; } int CountWords(char str[]) { int i, num; num = (__________) ? 1 : 0; i=1; while (str[i]!='\0') { if (_______________________) { num++; } __________; } return num; }

A、第17行: str[0] != ' '第21行: str[i]!=' ' && str[i-1] == ' '第25行: i++

B、第17行: str[0] == ' '第21行: str[i]!=' ' || str[i-1] == ' '第25行: i++

C、第17行: str[0] != '\0 '第21行: str[i]==' ' && str[i-1] == ' '第25行: i++

D、第17行: str[0] != ' '第21行: str[i]!=' ' && str[i-1] != ' '第25行: num++

指针的算术运算

1、【单选题】下列说法错误的是()。

A、指针指向数组元素时,指针算术运算才有意义

B、两个指针指向同一个数组时,指针相减才有意义

C、指针的算术运算允许通过对指针变量重复自增来访问数组的元素

D、p++就是将指针变量p加上一个字节

指针和一维数组

1、【判断题】当指针变量指向一维数组的时候,sizeof(数组名)和sizeof(指针变量名)的计算结果是相同的。

A、正确

B、错误

元素在二维数组中相对于首地址的偏移量

1、【单选题】二维数组a有m行n列,则在a[i][j]之前的元素个数为()

A、j*n+i

B、i*n+j

C、i*n+j-1

D、i*n+j+1

字符指针数组

1、【判断题】char *country[] = {America, England, Australia, China, Finland};这条语句定义了一个字符指针数组country,并用初始化列表中的每个字符串的首地址为字符指针数组country的元素进行初始化,并不是将初始化列表中的字符串保存到字符指针数组中。

A、正确

B、错误

第11周编程题在线测试

练兵区——编程题——不计入总分

第11周测验

1、【单选题】下面程序的功能是用指针变量作函数参数编程计算任意m×n阶矩阵的转置矩阵。要求用指向一维数组的指针变量即二维数组的行指针作函数参数。程序的运行结果如下:Please enter matrix:1 2 3 4↙1 2 3 4↙1 2 3 4↙The transposed matrix is:1 1 12 2 23 3 34 4 4按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define ROW 3 #define COL 4 void Transpose(int (*a)[COL], int (*at)[ROW], int row, int col); void InputMatrix(int (*s)[COL], int row, int col); void PrintMatrix(int (*s)[ROW], int row, int col); int main(void) { int s[ROW][COL];//s代表原矩阵 int st[COL][ROW];//st代表转置后的矩阵 printf(Please enter matrix:\n); InputMatrix(s, ROW, COL);//输入原矩阵,s指向矩阵s的第0行,是行指针 Transpose(s, st, ROW, COL);//对矩阵s进行转置,结果存放于st中 printf(The transposed matrix is:\n); PrintMatrix(st, COL, ROW); //输出转置矩阵,*st指向st的第0行,是行指针 return 0; } //函数功能: 对任意row行col列的矩阵a转置,转置后的矩阵为at void Transpose(____________,int (*at)[ROW], int row, int col) { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { _____________________; } } } void InputMatrix(___________, int row, int col) //输入矩阵元素 { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { scanf(%d, ___________);// 元素s[i][j] } } } void PrintMatrix(int ___________, int row, int col) //输出矩阵元素 { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { printf(%d\t, *(*(s+i)+j)); // 元素s[i][j] } printf( \n); } }

A、第20行: int (*a)[COL]第27行: *(*(at+j)+i) = *(*(a+i)+j)第32行: int(*s)[COL]第39行: *(s+i)+j第44行: (*s)[ROW]

B、第20行: int *a[COL]第27行: *(*(at+j)+i) = (*(a+i)+j)第32行: int(*s)[ROW]第39行: *(s+i)+j第44行: *s[COL]

C、第20行: int (*a)[ROW]第27行: *(at+j+i) = *(*(a+i)+j)第32行: int(*s)[COL]第39行: *(s+i+j)第44行: (*s)[ROW]

D、第20行: int (*a)[COL]第27行: *(*(at+j)+i) = *(*(a+i+j))第32行: int(*s)[ROW]第39行: *(s)+i+j第44行: (*s)[COL]

2、【单选题】口袋中有若干红、黄、蓝、白、黑5种颜色的球,每次从口袋中取出3个球,编程输出得到3种不同颜色的球的所有可能取法。下面程序用三重循环模拟取球过程,但每次取出的球如果与前面的球颜色相同就抛弃。程序的运行结果如下:1:RED,YELLOW,BLUE2:RED,YELLOW,WHITE3:RED,YELLOW,BLACK4:RED,BLUE,WHITE5:RED,BLUE,BLACK6:RED,WHITE,BLACK7:YELLOW,BLUE,WHITE8:YELLOW,BLUE,BLACK9:YELLOW,WHITE,BLACK10:BLUE,WHITE,BLACK按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { char *bColor[] = {RED,YELLOW,BLUE,WHITE,BLACK}; int i, j, k, m = 0; for (i=0; i5; i++) { for (________; j5; j++) { for (________; k5; k++) { m++; printf(%d:%s,%s,%s\n, ___________________); } } } return 0; }

A、第8行: j=i+1第10行: k=j+1第13行: m, bColor[i], bColor[j], bColor[k]

B、第8行: j=1第10行: k=1第13行: m, *bColor+i, *bColor+j, *bColor+k

C、第8行: j=i第10行: k=j第13行: m,*(bColor+i), *(bColor+j), *(bColor+k)

D、第8行: j=0第10行: k=0第13行: m, *bColor[i], *bColor[j], *bColor[k]

3、【单选题】char (*p)[10];该语句定义了一个

A、指向含有10个元素的一维字符型数组的指针变量p

B、指向长度为10的字符串的指针变量p

C、有10个元素的指针数组p,每个元素可以指向一个字符串

D、有10个元素的指针数组p,每个元素存放一个字符串

4、【单选题】设有以下定义: int a[3][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9}; int (*ptr)[3] = a; int *p = a[0];则以下能够正确表示数组元素a[1][2]的表达式是

A、*(*(ptr + 1) + 2)

B、*((*ptr + 1) + 2)

C、*(*(p + 5))

D、(*ptr + 1) + 2

5、【单选题】二维数组a有m行n列,则在a[i][j]之前的元素个数为

A、i*n+j

B、j*n+i

C、i*n+j-1

D、i*n+j+1

6、【单选题】下面关于表达式(*p)++和*p++的含义分析说明中,错误的是

A、(*p)++指的是先取出p指向的存储单元中的内容,然后将取出的数值加1,此时p不再指向原来的存储单元。

B、(*p)++指的是先取出p指向的存储单元中的内容,然后将取出的数值加1,而p仍然指向原来的存储单元。

C、*p++则指的是先取出p指向的存储单元中的内容,然后将p值加1,此时p不再指向原来的存储单元。

D、表达式(*p)++和*p++具有不同的含义,(*p)++并没有修改指针p的指向,而*p++则修改了指针p的指向。

7、【单选题】假设有下面定义语句:float a[10];float *p=a;则p++相当于是加上()个字节

A、sizeof(float)

B、1个字节

C、sizeof(p)

D、sizeof(a)

E、sizeof(float*)

8、【单选题】下列说法中错误的是

A、char *country[] = {"French", "England", "Japan", "China", "Finland"};这条语句定义了一个字符指针数组country,并将初始化列表中的字符串保存到字符指针数组中。

B、当指针变量指向一维数组的时候,sizeof(数组名)和sizeof(指针变量名)的计算结果是不相同的。

C、指针的算术运算允许通过对指针变量重复自增来访问数组的元素。

D、指针指向数组元素时,指针算术运算才是有意义的。

9、【单选题】下面程序希望得到的运行结果如下:Total string numbers = 3How are you但是现在代码存在错误,找出下面选项中修改正确的语句#include stdio.h void Print(char *arr[], int len); int main() { char *pArray[] = {How,are,you}; int num = sizeof(pArray) / sizeof(char); printf(Total string numbers = %d\n, num); Print(pArray, num); return 0; } void Print(char *arr[], int len) { int i; for (i=0; ilen; i++) { printf(%s , arr[i]); } printf(\n); }

A、第6行应该是: int num = sizeof(pArray) / sizeof(char*);

B、第12行应该是: void Print(char arr[], int len)

C、第5行应该是: char pArray[] = {"How","are","you"};

D、第6行应该是: int num = sizeof(pArray/char *);

10、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a[3],b; b=p[5]; printf(%d,b); return 0; }

A、9

B、5

C、6

D、8

11、【单选题】有以下程序段,则*(p[0]+1)所代表的数组元素是#include stdio.h int main() { int a[3][2]={1,2,3,4,5,6,},*p[3]; p[0]=a[1]; ..... return 0; }

A、a[1][1]

B、a[0][1]

C、a[1][0]

D、a[1][2]

12、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a[3][3],*p,i; p=a[0][0]; for(i=0;i9;i++) { p[i]=i+1; } printf(%d\n,a[1][2]); return 0; }

A、6

B、3

C、9

D、2

13、【单选题】如下程序的执行结果是 #includestdio.h int main() { int a[ ][4]={1,3,5,7,9,11,13,15,17,19,21,23}; int (*p)[4],i=1,j=2; p=a; printf(%d\n,*(*(p+i)+j)); return 0; }

A、13

B、9

C、11

D、17

14、【单选题】在以下程序段中的空白处填写适当的表达式或语句,使程序能正确引用c数组元素。#include stdio.h int main() { int c[4][5],(*p)[5],i,j,d=0; for(i=0;i4;i++) { for(j=0;j5;j++) { c[i][j]=d; d++; printf(%4d,c[i][j]); } printf(\n); } p=c; printf(%d,%d\n,____________); return 0; }

A、*(p[0]+2),c[0][2]

B、*(p+1)+3,c[1][3]

C、*(p+3),c[0][3]

D、p+1,c[0][1]

15、【单选题】下面给出的选项中,能定义为一个指针数组的语句是

A、int *ptr[5];

B、int (*ptr)[5];

C、int *(ptr[5]);

D、int ptr[5];

16、【单选题】若有定义“int *p[5];”,则以下叙述中正确的是

A、定义了一个指针数组p,该数组含有5个元素,每个元素都是基类型为int的指针变量

B、定义了一个基类型为int的指针变量p,该变量有5个指针

C、定义了一个名为*p的整型数组,该数组含有5个int类型元素

D、定义了一个可指向一维数组的指针变量p,所指一维数组应具有5个int类型元素

17、【单选题】设有定义语句int x[6]={2,4,6,8,5,7},*p=x,i;要求依次输出x数组6个元素中的值,不能完成此操作的语句是

A、for(i=0;i<6;i++) printf("%2d",(*p)++);

B、for(i=0;i<6;i++) printf("%2d",*(p++));

C、for(i=0;i<6;i++) printf("%2d",*(p+i));

D、for(i=0;i<6;i++) printf("%2d",*p++);

18、【单选题】若二维数组a有m行n列,则下面能够正确引用元素a[i][j]的为

A、*(*(a+i)+j)

B、*(a+j*n+i)

C、*(a+i*n+j)

D、*(*a+i)+j

19、【单选题】设有语句“int array[3][4];”,则在下面几种引用下标为i和j的数组元素的方法中,不正确的引用方式是________。

A、*(array + i*4 + j)

B、array[i][j]

C、*(*(array + i) + j)

D、*(array[i] + j)

20、【单选题】有int *p[10];以下说法错误的是________。

A、p++操作是合法的

B、p是数组名

C、p是一个指针数组

D、p中每个元素都是一个指针变量

练兵区——单选题——不计入总分

1、【单选题】口袋中有若干红、黄、蓝、白、黑5种颜色的球,每次从口袋中取出3个球,编程输出得到3种不同颜色的球的所有可能取法。下面程序用三重循环模拟取球过程,但每次取出的球如果与前面的球颜色相同就抛弃。程序的运行结果如下:1:RED,YELLOW,BLUE2:RED,YELLOW,WHITE3:RED,YELLOW,BLACK4:RED,BLUE,WHITE5:RED,BLUE,BLACK6:RED,WHITE,BLACK7:YELLOW,BLUE,WHITE8:YELLOW,BLUE,BLACK9:YELLOW,WHITE,BLACK10:BLUE,WHITE,BLACK按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h int main() { char *bColor[] = {RED,YELLOW,BLUE,WHITE,BLACK}; int i, j, k, m = 0; for (i=0; i5; i++) { for (________; j5; j++) { for (________; k5; k++) { m++; printf(%d:%s,%s,%s\n, ___________________); } } } return 0; }

A、第8行: j=i+1第10行: k=j+1第13行: m, bColor[i], bColor[j], bColor[k]

B、第8行: j=1第10行: k=1第13行: m, *bColor+i, *bColor+j, *bColor+k

C、第8行: j=i第10行: k=j第13行: m,*(bColor+i), *(bColor+j), *(bColor+k)

D、第8行: j=0第10行: k=0第13行: m, *bColor[i], *bColor[j], *bColor[k]

2、【单选题】二维数组a有m行n列,则在a[i][j]之前的元素个数为

A、i*n+j

B、j*n+i

C、i*n+j-1

D、i*n+j+1

3、【单选题】假设有下面定义语句:float a[10];float *p=a;则p++相当于是加上()个字节

A、sizeof(float)

B、1个字节

C、sizeof(p)

D、sizeof(a)

E、sizeof(float*)

4、【单选题】若二维数组a有m行n列,则下面能够正确引用元素a[i][j]的为

A、*(*(a+i)+j)

B、*(a+j*n+i)

C、*(a+i*n+j)

D、*(*a+i)+j

5、【单选题】char (*p)[10];该语句定义了一个

A、指向含有10个元素的一维字符型数组的指针变量p

B、指向长度为10的字符串的指针变量p

C、有10个元素的指针数组p,每个元素可以指向一个字符串

D、有10个元素的指针数组p,每个元素存放一个字符串

6、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a[3][3],*p,i; p=a[0][0]; for(i=0;i9;i++) { p[i]=i+1; } printf(%d\n,a[1][2]); return 0; }

A、6

B、3

C、9

D、2

7、【单选题】如下程序的执行结果是#includestdio.h int main() { int a[ ][4]={1,3,5,7,9,11,13,15,17,19,21,23}; int (*p)[4],i=1,j=2; p=a; printf(%d\n,*(*(p+i)+j)); return 0; }

A、13

B、9

C、11

D、17

8、【单选题】设有以下定义: int a[3][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9}; int (*ptr)[3] = a; int *p = a[0];则以下能够正确表示数组元素a[1][2]的表达式是

A、*(*(ptr + 1) + 2)

B、*((*ptr + 1) + 2)

C、*(*(p + 5))

D、(*ptr + 1) + 2

9、【单选题】下面关于表达式(*p)++和*p++的含义分析说明中,错误的是

A、(*p)++指的是先取出p指向的存储单元中的内容,然后将取出的数值加1,此时p不再指向原来的存储单元。

B、(*p)++指的是先取出p指向的存储单元中的内容,然后将取出的数值加1,而p仍然指向原来的存储单元。

C、*p++则指的是先取出p指向的存储单元中的内容,然后将p值加1,此时p不再指向原来的存储单元。

D、表达式(*p)++和*p++具有不同的含义,(*p)++并没有修改指针p的指向,而*p++则修改了指针p的指向。

10、【单选题】以下程序运行后的输出结果是#include stdio.h int main() { int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a[3],b; b=p[5]; printf(%d,b); return 0; }

A、9

B、5

C、6

D、8

11、【单选题】有以下程序段,则*(p[0]+1)所代表的数组元素是#include stdio.h int main() { int a[3][2]={1,2,3,4,5,6,},*p[3]; p[0]=a[1]; ..... return 0; }

A、a[1][1]

B、a[0][1]

C、a[1][0]

D、a[1][2]

12、【单选题】在以下程序段中的空白处填写适当的表达式或语句,使程序能正确引用c数组元素。#include stdio.h int main() { int c[4][5],(*p)[5],i,j,d=0; for(i=0;i4;i++) { for(j=0;j5;j++) { c[i][j]=d; d++; printf(%4d,c[i][j]); } printf(\n); } p=c; printf(%d,%d\n,____________); return 0; }

A、*(p[0]+2),c[0][2]

B、*(p+1)+3,c[1][3]

C、*(p+3),c[0][3]

D、p+1,c[0][1]

13、【单选题】下面给出的选项中,能定义为一个指针数组的语句是

A、int *ptr[5];

B、int (*ptr)[5];

C、int *(ptr[5]);

D、int ptr[5];

14、【单选题】下面程序的功能是用指针变量作函数参数编程计算任意m×n阶矩阵的转置矩阵。要求用指向一维数组的指针变量即二维数组的行指针作函数参数。程序的运行结果如下:Please enter matrix:1 2 3 4↙1 2 3 4↙1 2 3 4↙The transposed matrix is:1 1 12 2 23 3 34 4 4按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include stdio.h #define ROW 3 #define COL 4 void Transpose(int (*a)[COL], int (*at)[ROW], int row, int col); void InputMatrix(int (*s)[COL], int row, int col); void PrintMatrix(int (*s)[ROW], int row, int col); int main(void) { int s[ROW][COL];//s代表原矩阵 int st[COL][ROW];//st代表转置后的矩阵 printf(Please enter matrix:\n); InputMatrix(s, ROW, COL);//输入原矩阵,s指向矩阵s的第0行,是行指针 Transpose(s, st, ROW, COL);//对矩阵s进行转置,结果存放于st中 printf(The transposed matrix is:\n); PrintMatrix(st, COL, ROW); //输出转置矩阵,*st指向st的第0行,是行指针 return 0; } //函数功能: 对任意row行col列的矩阵a转置,转置后的矩阵为at void Transpose(____________,int (*at)[ROW], int row, int col) { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { _____________________; } } } void InputMatrix(___________, int row, int col) //输入矩阵元素 { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { scanf(%d, ___________);// 元素s[i][j] } } } void PrintMatrix(int ___________, int row, int col) //输出矩阵元素 { int i, j; for (i=0; irow; i++) { for (j=0; jcol; j++) { printf(%d\t, *(*(s+i)+j)); // 元素s[i][j] } printf( \n); } }

A、第20行: int (*a)[COL]第27行: *(*(at+j)+i) = *(*(a+i)+j)第32行: int(*s)[COL]第39行: *(s+i)+j第44行: (*s)[ROW]

B、第20行: int *a[COL]第27行: *(*(at+j)+i) = (*(a+i)+j)第32行: int(*s)[ROW]第39行: *(s+i)+j第44行: *s[COL]

C、第20行: int (*a)[ROW]第27行: *(at+j+i) = *(*(a+i)+j)第32行: int(*s)[COL]第39行: *(s+i+j)第44行: (*s)[ROW]

D、第20行: int (*a)[COL]第27行: *(*(at+j)+i) = *(*(a+i+j))第32行: int(*s)[ROW]第39行: *(s)+i+j第44行: (*s)[COL]

15、【单选题】下列说法中错误的是

A、char *country[] = {"French", "England", "Japan", "China", "Finland"};这条语句定义了一个字符指针数组country,并将初始化列表中的字符串保存到字符指针数组中。

B、当指针变量指向一维数组的时候,sizeof(数组名)和sizeof(指针变量名)的计算结果是不相同的。

C、指针的算术运算允许通过对指针变量重复自增来访问数组的元素。

D、指针指向数组元素时,指针算术运算才是有意义的。

16、【单选题】下面程序希望得到的运行结果如下:Total string numbers = 3How are you但是现在代码存在错误,找出下面选项中修改正确的语句#include stdio.h void Print(char *arr[], int len); int main() { char *pArray[] = {How,are,you}; int num = sizeof(pArray) / sizeof(char); printf(Total string numbers = %d\n, num); Print(pArray, num); return 0; } void Print(char *arr[], int len) { int i; for (i=0; ilen; i++) { printf(%s , arr[i]); } printf(\n); }

A、第6行应该是: int num = sizeof(pArray) / sizeof(char*);

B、第12行应该是: void Print(char arr[], int len)

C、第5行应该是: char pArray[] = {"How","are","you"};

D、第6行应该是: int num = sizeof(pArray/char *);

17、【单选题】若有定义“int *p[5];”,则以下叙述中正确的是

A、定义了一个指针数组p,该数组含有5个元素,每个元素都是基类型为int的指针变量

B、定义了一个基类型为int的指针变量p,该变量有5个指针

C、定义了一个名为*p的整型数组,该数组含有5个int类型元素

D、定义了一个可指向一维数组的指针变量p,所指一维数组应具有5个int类型元素

18、【单选题】设有定义语句int x[6]={2,4,6,8,5,7},*p=x,i;要求依次输出x数组6个元素中的值,不能完成此操作的语句是

A、for(i=0;i<6;i++) printf("%2d",(*p)++);

B、for(i=0;i<6;i++) printf("%2d",*(p++));

C、for(i=0;i<6;i++) printf("%2d",*(p+i));

D、for(i=0;i<6;i++) printf("%2d",*p++);

19、【单选题】设有语句“int array[3][4];”,则在下面几种引用下标为i和j的数组元素的方法中,不正确的引用方式是________。

A、*(array + i*4 + j)

B、array[i][j]

C、*(*(array + i) + j)

D、*(array[i] + j)

20、【单选题】有int *p[10];以下说法错误的是________。

A、p++操作是合法的

B、p是数组名

C、p是一个指针数组

D、p中每个元素都是一个指针变量

关键字typedef

1、【判断题】关键字typedef主要用于定义一种新的数据类型。

A、正确

B、错误

结构体变量的定义

1、【单选题】下面哪条语句是正确的。

A、typedef struct student { long studentID; char studentName[10]; char studentSex; int yearOfBirth; int score[4]; }STUDENT; STUDENT stu1 = {100310121, "王刚", 'M', 1991, {72,83,90,82}};

B、typedef struct STUDENT { long studentID; char studentName[10]; char studentSex; int yearOfBirth; int score[4]; }; STUDENT stu1 = {100310121, "王刚", 'M', 1991, {72,83,90,82}};

C、struct { long studentID; char studentName[10]; char studentSex; int yearOfBirth; int score[4]; }; struct stu1;

D、struct student{ long studentID; char studentName[10]; char studentSex; int yearOfBirth; int score[4]; }STUDENT;STUDENT stu1 = {100310121, "王刚", 'M', 1991, {72,83,90,82}};

结构体的嵌套

1、【判断题】在一个结构体内可以包含另一个不同类型的结构体作为其成员。

A、正确

B、错误

结构体类型所占内存的字节数

1、【单选题】下列说法错误的是()。

A、结构体类型所占内存的字节数就是结构体的每个成员类型所占内存字节数的总和。

B、结构体在内存中所占的字节数不仅与所定义的结构体类型有关,还与计算机系统本身有关。

C、计算结构体所占内存的字节数时,一定要使用sizeof运算符。

D、内存对齐的主要目的就是为了提高内存的寻址效率。不同的系统和编译器,内存对齐方式可能会不同,是机器相关的。

对结构体的操作

1、【单选题】下列说法错误的是()。

A、对结构体变量的成员的访问是通过名字并使用成员选择运算符来访问的。

B、只能在相同类型的结构体变量之间进行赋值。

C、可以使用==和!=来判定两个结构体相等或不等。

D、对嵌套的结构体成员,必须以级联的方式来访问。

结构体变量的访问

1、【单选题】已知:typedef struct date { int year; int month; int day; }DATE; typedef struct student { long studentID; char studentName[10]; char studentSex; DATE birthday; int score[4]; }STUDENT; STUDENT stu1; STUDENT *pt = stu1;则下列访问结构体变量的方法中,哪个是错误的。

A、stu1. birthday. year = 1999;

B、(*pt). birthday. year = 1999;

C、pt -> birthday -> year = 1999;

D、pt -> birthday. year = 1999;

向函数传递结构体

1、【单选题】下列说法错误的是()。

A、用结构体变量做函数参数,是将整个结构体的所有成员的内容传给被调函数,因此在被调函数中对结构体内容的修改不影响原结构体变量。

B、用结构体数组/结构体指针作函数参数的参数传递效率比用结构体变量做函数参数的参数传递效率要高。

C、用结构体数组/结构体指针作函数参数,是复制结构体的首地址给被调函数,因此在被调函数中可以修改结构体指针所指向的结构体的内容。

D、数组和结构体变量都不可以用做函数返回值的类型。

枚举类型

1、【单选题】下列对枚举类型的使用的代码中错误的是()。

A、enum {no, yes, none}answer; if (answer == yes) { printf("Yes\n"); }

B、enum response{no = -1, yes = 1, none = 0}; enum response answer;

C、answer = yes; printf("%d", answer);

D、answer = "yes"; printf("%s", answer);

2、【判断题】和整型、实型、字符型一样,枚举类型也是一种基本数据类型。

A、正确

B、错误

共用体类型

1、【单选题】下列说法错误的是()。

A、编译器只为共用体中最大的成员分配足够的内存空间。共用体的成员在这个空间内是彼此覆盖的,都从同一起始地址开始存储。

B、与结构体不同的是,共用体在内存中所占空间的字节数取决于占空间最多的那个成员变量。

C、共用体变量在每一瞬时只能保存一个成员,起作用的成员是最后一次赋值的成员。

D、共用体和结构体的成员访问方式以及成员的初始化方式都是一样的,都使用成员选择运算符访问成员变量,都可以在定义的时候对所有成员进行初始化。

指针和内存

1、【判断题】指针变量所占的内存被释放了,也就意味着它所指向的动态内存也会被自动释放。

A、正确

B、错误

2、【判断题】用free释放指针变量所指向的内存以后,就意味着该指针变量变成了空指针。

A、正确

B、错误

函数fgetc()和feof()

1、【判断题】函数fgetc()的功能是从fp所指的文件中读取一个字符,并将位置指针指向下一个字符。若读取成功,则返回该字符,若读到文件末尾或者读取出错,则返回EOF。EOF是一个符号常量,通常在stdio.h中定义为-1。

A、正确

B、错误

2、【判断题】函数feof()的功能是检查是否到达文件尾,只要读完最后一个字符、文件位置指针指向文件尾时(EOF)时,就会返回非0值,否则返回0值。

A、正确

B、错误

fgets()与fputs()

1、【判断题】fgets()与gets()的不同点是,gets()从指定的流读字符串,读到换行符时将换行符替换为'\0',读入的字符串中不会保留'\n',而fgets()从指定的流读字符串,读到换行符时不替换为'\0',读入的字符串中会保留'\n',在'\n'的后面会再添加一个'\0'。

A、正确

B、错误

2、【判断题】fputs()是向任意流写数据,puts()是向标准输出流写数据,二者在写数据时的不同之处是,puts()会在写入的字符串末尾自动添加换行符,而fputs()不会在写入的字符串末尾自动添加换行符,除非字符串本身含有换行符。

A、正确

B、错误



    评论留言

    昵称

    个人资料
    个人资料
    学通智库​ 是专为 ​学起Plus、超星学习通、安徽继续教育、云上河开​ 等主流学习平台用户打造的一站式资源中心。
    • 文章59948
    • 评论0
    • 微语0
    标签