菏诫矛槐十胖巍册狗笆跺峦碘
第1周——初识C语言从认识变量和常量开始
codeblocks介绍——从Hello World开始
1、单选题:
#include <stdio.h>是
A: 编译预处理指令
B: 语句
C: 函数
D: 程序入口
答案: 编译预处理指令
debug
1、单选题:
codeblocks中运行到下一步(next line)的快捷键是
A: F7
B: F5
C: F8
D: F11
答案: F7
变量在内存中所占的字节数
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: #abc123
D: 123abc
E: o*k
F: a?
G: a+b
H: %a
I: b!
答案: _a1
2、单选题:
以下不适合定义为用户标识符的是
A: int
B: a2
C: def2
D: _3com_
E: PI
F: Source
G: abc
答案: int
3、单选题:
#include <stdio.h>是
A: 编译预处理指令
B: 语句
C: 函数
D: 什么都不是
E: 有语法错误
答案: 编译预处理指令
4、单选题:
在windows下,程序编译链接后形成的可执行文件是
A: .obj文件
B: .exe文件
C: .o文件
D: .c文件
E: .h文件
答案: .exe文件
5、单选题:
程序编译链接后显示” 0 error,0 warning” 代表
A: 程序中没有语法错误
B: 程序是正确的
C: 程序是不正确的
D: 程序中可能存在语法错误
E: 程序中有语义错误
答案: 程序中没有语法错误
6、单选题:
用8位无符号二进制数能表示的最大十进制数为
A: 255
B: 127
C: 128
D: 256
答案: 255
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: 不允许字符型和浮点型相加
答案: ‘A’+1.6的结果是浮点型;
a的值还是整型
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
答案: run;
build
11、单选题:
程序的开发步骤中不包括
A: 撰写文档
B: 运行程序
C: 编译链接
D: 程序测试
E: 编辑(编写代码)
答案: 撰写文档
12、单选题:
下列说法中错误的是()
A: 尾数决定了实数的表数范围,阶码决定了实数的表数精度。
B: 内存是按位编址的。
C: 有符号和无符号整数的表数范围是相同的。
D: int型在所有的计算机上都占4个字节的存储单元。
E: 编译器按变量定义的类型对不同类型的变量分配不同大小的内存空间。
F: 内存是按字节编址的。
G: 对于同样的尾数,阶码的值越大,则浮点数所表示的数值的绝对值就越大。
H: sizeof是编译时执行的运算符,不会导致额外的运行时间开销。
答案: 尾数决定了实数的表数范围,阶码决定了实数的表数精度。;
内存是按位编址的。;
有符号和无符号整数的表数范围是相同的。;
int型在所有的计算机上都占4个字节的存储单元。
13、单选题:
若有定义:int a=8,b=5,c; ,执行语句c=a/b+0.4;后,c的值为
A: 1
B: 1.4
C: 2.0
D: 2
答案: 1
14、单选题:
在C语言中,字符型数据在内存中以字符的( )形式存放
A: ASCII码
B: 国标码
C: BCD码
D: 反码
答案: ASCII码
15、单选题:
以下符合C语言语法的实型常量是
A: 5e-3
B: 3.14.159e
C: 1.2e0.5
D: e15
答案: 5e-3
16、单选题:
以下选项中可作为C语言合法整数的是
A: 0xffa
B: 10110B
C: 038x
D: x2a2
答案: 0xffa
17、单选题:
下列说法正确的是
A: 在C语言中,变量必须先定义后使用。
B: 一条变量定义语句可定义多个同类型的变量。
C: C89规定所有变量必须在第一条可执行语句前定义。
D: const常量只能在定义时赋值。
E: 实型常量的默认类型是double类型。
F: 一条变量定义语句不可以同时定义多个变量。
G: 不同类型的变量分配的存储空间大小都是相同的。
H: 在C语言中,所有变量都必须在定义时进行初始化。
I: 变量在没有初始化的时候,其值都是0
J: 宏常量有数据类型,编译器在宏替换时可以进行类型检查。
答案: 在C语言中,变量必须先定义后使用。;
一条变量定义语句可定义多个同类型的变量。;
C89规定所有变量必须在第一条可执行语句前定义。;
const常量只能在定义时赋值。;
实型常量的默认类型是double类型。
18、单选题:
下列变量定义中合法的是
A: long ao=0xfdaL;
B: short _a=1-.1e-1;
C: double b=1+5e2.5;
D: float 2_and=1-e-3;
答案: long ao=0xfdaL;
练兵区——单选题——不计入总分
1、单选题:
下列选项中,合法的C语言标识符是
A: _a1
B: width
C: #abc123
D: 123abc
E: o*k
F: a?
G: a+b
H: %a
I: b!
答案: _a1;
width
2、单选题:
以下不适合定义为用户标识符的是
A: float
B: main
C: define
D: _3com_
E: PI
F: Source
G: abc
答案: float ;
main;
define
3、单选题:
#include <stdio.h>是
A: 编译预处理指令
B: 语句
C: 函数
D: 什么都不是
E: 有语法错误
答案: 编译预处理指令
4、单选题:
在windows下,程序编译链接后形成的可执行文件是
A: .obj文件
B: .exe文件
C: .o文件
D: .c文件
E: .h文件
答案: .exe文件
5、单选题:
程序编译链接后显示” 0 error,0 warning” 代表
A: 程序中没有语法错误
B: 程序是正确的
C: 程序是不正确的
D: 程序中可能存在语法错误
E: 程序中有语义错误
答案: 程序中没有语法错误
6、单选题:
用8位无符号二进制数能表示的最大十进制数为
A: 255
B: 127
C: 128
D: 256
答案: 255
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: 不允许字符型和浮点型相加
答案: ‘A’+1.6的结果是浮点型;
a的值还是整型
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
答案: run;
build
11、单选题:
程序的开发步骤中不包括
A: 撰写文档
B: 运行程序
C: 编译链接
D: 程序测试
E: 编辑(编写代码)
答案: 撰写文档
12、单选题:
下列说法中错误的是()
A: 尾数决定了实数的表数范围,阶码决定了实数的表数精度。
B: 内存是按位编址的。
C: 有符号和无符号整数的表数范围是相同的。
D: int型在所有的计算机上都占4个字节的存储单元。
E: 编译器按变量定义的类型对不同类型的变量分配不同大小的内存空间。
F: 内存是按字节编址的。
G: 对于同样的尾数,阶码的值越大,则浮点数所表示的数值的绝对值就越大。
H: sizeof是编译时执行的运算符,不会导致额外的运行时间开销。
答案: 尾数决定了实数的表数范围,阶码决定了实数的表数精度。;
内存是按位编址的。;
有符号和无符号整数的表数范围是相同的。;
int型在所有的计算机上都占4个字节的存储单元。
13、单选题:
若有定义:int a=8,b=5,c; ,执行语句c=a/b+0.4;后,c的值为
A: 1
B: 1.4
C: 2.0
D: 2
答案: 1
14、单选题:
在C语言中,字符型数据在内存中以字符的( )形式存放
A: ASCII码
B: 国标码
C: BCD码
D: 反码
答案: ASCII码
15、单选题:
以下符合C语言语法的实型常量是
A: 5e-3
B: 3.14.159e
C: 1.2e0.5
D: e15
答案: 5e-3
16、单选题:
以下选项中可作为C语言合法整数的是
A: 0xffa
B: 10110B
C: 038x
D: x2a2
答案: 0xffa
17、单选题:
下列说法正确的是
A: 在C语言中,变量必须先定义后使用。
B: 一条变量定义语句可定义多个同类型的变量。
C: C89规定所有变量必须在第一条可执行语句前定义。
D: const常量只能在定义时赋值。
E: 实型常量的默认类型是double类型。
F: 一条变量定义语句不可以同时定义多个变量。
G: 不同类型的变量分配的存储空间大小都是相同的。
H: 在C语言中,所有变量都必须在定义时进行初始化。
I: 变量在没有初始化的时候,其值都是0
J: 宏常量有数据类型,编译器在宏替换时可以进行类型检查。
答案: 在C语言中,变量必须先定义后使用。;
一条变量定义语句可定义多个同类型的变量。;
C89规定所有变量必须在第一条可执行语句前定义。;
const常量只能在定义时赋值。;
实型常量的默认类型是double类型。
18、单选题:
下列变量定义中合法的是
A: long ao=0xfdaL;
B: short _a=1-.1e-1;
C: double b=1+5e2.5;
D: float 2_and=1-e-3;
答案: long ao=0xfdaL;
第2周——数字间的那些事儿,做点计算哈
不同类型数据的运算
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;
答案: int a=b=c=0;
强制类型转换
1、判断题:
强制类型转换运算符就是强制改变一个变量原有的数据类型。
A: 正确
B: 错误
答案: 错误
运算符的优先级和结合性
1、判断题:
二元的算术运算符的结合性都是左结合。
A: 正确
B: 错误
答案: 正确
第3周——从键盘中来,到键盘中去,开始输入和输出啦
%c格式转换说明
1、判断题:
用c格式符输入字符型数据的时候,为了避免将输入缓冲区中的空白字符(空格、回车换行符、Tab键)作为有效字符读入,可以在%c前面加一个空格。
A: 正确
B: 错误
答案: 正确
单个字符的输入输出
1、判断题:
单个字符既可以以c格式符也可以以d格式符输出,前者是输出这个字符,后者是输出这个字符的ASCII码值。
A: 正确
B: 错误
答案: 正确
格式字符
1、判断题:
在调用printf函数输出数据时,当数据的实际位宽大于printf函数中的指定位宽时,将按照数据的实际位宽输出数据。
A: 正确
B: 错误
答案: 正确
第4周——无处不在的抉择
判断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配对
答案: else总是和前面离它最近的且还未和其他else匹配的在同一语句块内同一层次的if配对
2、判断题:
条件运算符是C语言中唯一的一个三元运算符.
A: 正确
B: 错误
答案: 正确
浮点数的表数精度
1、单选题:
下列说法错误的是()。
A: 浮点数并非真正意义上的实数,只是其在某种范围内的近似。
B: 浮点数能精确表示的数字位数取决于这种类型的浮点数的有效数字位数。
C: 使用更多的位来存储阶码,将会扩大浮点数的表数精度。
D: 受浮点数表数精度的限制,因此对于浮点数不能直接比较其是否相等,应该比较其是否近似相等。
答案: 使用更多的位来存储阶码,将会扩大浮点数的表数精度。
程序测试
1、单选题:
下列说法错误的是()。
A: 软件测试的目的就是证明程序的正确性,即给定特定的输入,通过运行被测程序,检查程序的输出是否与预期结果一致,进而验证程序的正确性。
B: 白盒测试就是在完全了解程序的结构和处理过程的情况下,按照程序内部的逻辑测试程序,检验程序中的每条逻辑路径是否都能按预定要求正确工作。黑盒测试就是把系统看成一个黑盒子,不考虑程序内部的逻辑结构和处理过程,只根据需求规格说明书的要求,设计测试用例,检查程序的功能是否符合它的功能说明。
C: 在选择测试用例时,不仅要选取合理的输入数据,还要选取一些不合理的输入数据,以及某些极端的边界点或临界点等,对程序进行测试
D: 由于修复了旧的bug的同时,往往又会产生新的bug,因此往往还需要对所有出现过的bug重新测试一遍,看其是否会重新出现,并给确认代码修改后没有引入新的bug,即修改代码后需要进行回归测试。
答案: 软件测试的目的就是证明程序的正确性,即给定特定的输入,通过运行被测程序,检查程序的输出是否与预期结果一致,进而验证程序的正确性。
第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 %dn”,a<b?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
答案: the output data is 7
2、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{ int a,b,c;
a=10;
b=20;
c=(a%b<1)||(a/b>1);
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
答案: 10,0,0
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+b>c && b+c>a && a+c>b)
{
s = 1/2 * (a + b + c);
area = sqrt(s * (s - a) * (s - b) * (s - c));
printf("area=%.2fn", area);
}
else
{
printf("It is not a trianglen");
}
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);
答案: 第11行: s = 1/2 * (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 = %fn”, data1, data2, data1 + data2);
break;
case ‘-‘:
printf(“%f – %f = %fn”, data1, data2, data1 – data2);
break;
case ‘*’:
printf(“%f * %f = %fn”, data1, data2, data1 * data2);
break;
case ‘/’:
printf(“%f/%f = %fn”, 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 = %fn”, data1, data2, data1/data2);同时,第1行语句下方应加入#include <math.h>#define EPS 1e-6
B: default分支缺少break语句
C: 没有错误
D: 第20行语句有错误,改成:if (data2=0) printf(“Division by zero!n”);else printf(“%f/%f = %fn”, data1, data2, data1/data2);
答案: 第20行语句有错误,改成:if (fabs(data2)<=EPS) printf(“Division by zero!n”);else printf(“%f/%f = %fn”, data1, data2, data1/data2);同时,第1行语句下方应加入#include <math.h>#define EPS 1e-6
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
答案: (x-y)<-10||!(y-x)>10
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;
}
答案: {
a=b;
b=a;
}
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=%dn”, a, b) ;
return 0;
}
A: a=2, b=2
B: a=2, b=1
C: a=1, b=1
D: a=1, b=0
答案: a=2, b=2
8、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=5,b=4,c=3,d;
d=(a>b>c);
printf(“%dn”,d);
return 0;
}
A: 0
B: 1
C: 5
D: 4
E: 3
答案: 0
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: 有语法错误
答案: **0****2**
10、单选题:
下面程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=3,b=4,c=5,d=2;
if(a>b)
{
if(b>c)
{
printf(“%d”,d++ +1);
}
else
{
printf(“%d”,++d +1);
}
}
printf(“%dn”,d);
return 0;
}
A: 2
B: 3
C: 43
D: 44
答案: 2
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 evenn”, m);
}
else //不能被2整除,则是正奇数
{
printf(“%d is a positive oddn”, m);
}
}
_______________ //判断是否为负数
{
_______________
{
printf(“%d is a negative evenn”, m); //是负偶数
}
else
{
printf(“%d is a negative oddn”, m); //是负奇数
}
}
else
{
printf(“%d is zero.It is an evenn”, 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)
答案: 第19行代码: else if(m < 0)第22行代码: if (m % 2 == 0)
12、单选题:
程序功能:从键盘输入一个字符,判别它是否为大写字母。如果是,将它转换成小写字母,如果不是,不转换。在屏幕上输出最后得到的字符。程序代码如下,为实现上述功能,请将第8行标号处缺少的语句填写完整。#include<stdio.h>
int main()
{
char c;
printf(“Please input a character:”);
scanf(“%c”,&c);
if(c >=’A’&&c <= ‘Z’)
c =_______________;
printf(“%cn”,c);
return 0;
}
A: c+32
B: c+48
C: C+65
D: C+97
答案: c+32
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
答案: 123
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); //x<0,则y=-exp(x)
}
printf("y=%fn", y);
return 0;
}
A: else if (x == 0)
B: else if (x = 0)
C: if (x == 0)
D: if (x = 0)
答案: else if (x == 0)
15、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=1,b=2,m=0,n=0,k;
k=(n=b>a)||(m=a<b);
printf(“%d,%dn”,k,m);
return 0;
}
A: 1,0
B: 0,0
C: 0,1
D: 1,1
答案: 1,0
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 = %.2fn”, p);
}
else
{
if (disc > EPS) /* 判别式大于0时,输出两不等实根 */
{
printf(“x1 = %.2f, x2 = %.2fn”, p+q, p-q);
}
else /* 判别式小于0时,输出两共轭复根 */
{
printf(“x1 = %.2f+%.2fi, “, p, q);
printf(“x2 = %.2f-%.2fin”, p, q);
}
}
return 0;
}
A: if (fabs(a) <= EPS)
B: if (a <= EPS)
C: if (a=0)
D: if (a<= EPS || a>=-EPS)
答案: if (fabs(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语句那样起到判断表达式真假的作用。
答案: case后的“常量表达式”的类型只能是整型。;
若case后面的语句省略不写,则表示它什么也不做。;
switch语句中的break和default可有可无。
练兵区——单选题——不计入总分
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 evenn”, m);
}
else //不能被2整除,则是正奇数
{
printf(“%d is a positive oddn”, m);
}
}
_______________ //判断是否为负数
{
_______________
{
printf(“%d is a negative evenn”, m); //是负偶数
}
else
{
printf(“%d is a negative oddn”, m); //是负奇数
}
}
else
{
printf(“%d is zero.It is an evenn”, 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)
答案: 第19行代码: else 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: 有语法错误
答案: **0****2**
3、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=1,b=2,m=0,n=0,k;
k=(n=b>a)||(m=a<b);
printf(“%d,%dn”,k,m);
return 0;
}
A: 1,0
B: 0,0
C: 0,1
D: 1,1
答案: 1,0
4、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{
int a,b,c;
a=10;
b=20;
c=(a%b<1)||(a/b>1);
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
答案: 10,0,0
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 = %fn”, data1, data2, data1 + data2);
break;
case ‘-‘:
printf(“%f – %f = %fn”, data1, data2, data1 – data2);
break;
case ‘*’:
printf(“%f * %f = %fn”, data1, data2, data1 * data2);
break;
case ‘/’:
printf(“%f/%f = %fn”, 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 = %fn”, data1, data2, data1/data2);同时,第1行语句下方应加入#include <math.h>#define EPS 1e-6
B: default分支缺少break语句
C: 没有错误
D: 第20行语句有错误,改成:if (data2=0) printf(“Division by zero!n”);else printf(“%f/%f = %fn”, data1, data2, data1/data2);
答案: 第20行语句有错误,改成:if (fabs(data2)<=EPS) printf(“Division by zero!n”);else printf(“%f/%f = %fn”, data1, data2, data1/data2);同时,第1行语句下方应加入#include <math.h>#define EPS 1e-6
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;
}
答案: {
a=b;
b=a;
}
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=%dn”, a, b) ;
return 0;
}
A: a=2, b=2
B: a=2, b=1
C: a=1, b=1
D: a=1, b=0
答案: a=2, b=2
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
答案: 123
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); //x<0,则y=-exp(x)
}
printf("y=%fn", y);
return 0;
}
A: else if (x == 0)
B: else if (x = 0)
C: if (x == 0)
D: if (x = 0)
答案: else 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 = %.2fn", p);
}
else
{
if (disc > EPS) /* 判别式大于0时,输出两不等实根 */
{
printf("x1 = %.2f, x2 = %.2fn", p+q, p-q);
}
else /* 判别式小于0时,输出两共轭复根 */
{
printf("x1 = %.2f+%.2fi, ", p, q);
printf("x2 = %.2f-%.2fin", p, q);
}
}
return 0;
}
A: if (fabs(a) <= EPS)
B: if (a <= EPS)
C: if (a=0)
D: if (a<= EPS || a>=-EPS)
答案: if (fabs(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+b>c && b+c>a && a+c>b)
{
s = 1/2 * (a + b + c);
area = sqrt(s * (s - a) * (s - b) * (s - c));
printf("area=%.2fn", area);
}
else
{
printf("It is not a trianglen");
}
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);
答案: 第11行: s = 1/2 * (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
答案: (x-y)<-10||!(y-x)>10
13、单选题:
程序功能:从键盘输入一个字符,判别它是否为大写字母。如果是,将它转换成小写字母,如果不是,不转换。在屏幕上输出最后得到的字符。程序代码如下,为实现上述功能,请将第8行标号处缺少的语句填写完整。#include<stdio.h>
int main()
{
char c;
printf(“Please input a character:”);
scanf(“%c”,&c);
if(c >=’A’&&c <= ‘Z’)
c =_______________;
printf(“%cn”,c);
return 0;
}
A: c+32
B: c+48
C: c+65
D: c+97
答案: c+32
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 %dn”,a<b?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
答案: the output data is 7
15、单选题:
以下程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=5,b=4,c=3,d;
d=(a>b>c);
printf(“%dn”,d);
return 0;
}
A: 0
B: 1
C: 5
D: 4
E: 3
答案: 0
16、单选题:
下面程序运行后的输出结果是#include <stdio.h>
int main()
{
int a=3,b=4,c=5,d=2;
if(a>b)
{
if(b>c)
{
printf(“%d”,d++ +1);
}
else
{
printf(“%d”,++d +1);
}
}
printf(“%dn”,d);
return 0;
}
A: 2
B: 3
C: 43
D: 44
答案: 2
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语句那样起到判断表达式真假的作用。
答案: case后的“常量表达式”的类型只能是整型。;
若case后面的语句省略不写,则表示它什么也不做。;
switch语句中的break和default可有可无。
赋值中的自动类型转换
1、单选题:
在赋值操作中,当赋值表达式左侧的变量的类型与右侧的表达式的类型不一致的时候,下面说法正确的是()。
A: 在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,会发生自动类型转换,赋值表达式的结果类型是赋值运算符左侧变量的类型。
B: 在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,赋值表达式的结果类型是赋值运算符右侧表达式的类型。
C: 在赋值操作中,只要赋值运算符左侧的变量的类型与右侧的表达式的类型不一致,就会发生数值溢出。
D: 在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,要么发生数值溢出,要么发生数值精度的损失。
答案: 在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,会发生自动类型转换,赋值表达式的结果类型是赋值运算符左侧变量的类型。
第5周——周而复始的循环之道
嵌套循环
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后面的语句
答案: 转到标号A所在的语句行与执行
程序调试
1、单选题:
下列说法错误的是()。
A: 程序测试的目的就是验证程序的正确性。
B: 程序中常见的错误有三种:编译错误,链接错误,以及运行时错误。
C: 编译错误通常是由语法错误造成的。
D: 运行时错误是指在程序运行时发生的错误,运行时错误有两种:一种是导致程序的运行结果与预期的不一致,另一种是导致程序无法正常运行。
答案: 程序测试的目的就是验证程序的正确性。
第5周测验
1、单选题:
程序运行后的输出结果是#include <stdio.h>
int main()
{
int i;
for(i=0;i<3;i++)
switch(i)
{
case 0: printf(“%d”,i);
case 2: printf(“%d”,i);
&nb
上方为免费预览版答案,如需购买完整答案,请点击下方红字:
为了方便下次阅读,建议在浏览器添加书签收藏本网页
添加书签方法:
1.电脑按键盘的Ctrl键+D键即可收藏本网页
2.手机浏览器可以添加书签收藏本网页
点击浏览器底部菜单-【添加书签】-收藏本网页
点击浏览器底部菜单-【书签/历史】-可查看本网页
获取更多慕课答案,欢迎在浏览器访问我们的网站:
http://mooc.mengmianren.com
注:请切换至英文输入法输入域名,如果没有成功进入网站,请输入完整域名:http://mooc.mengmianren.com/
我们的公众号
打开手机微信,扫一扫下方二维码,关注微信公众号:萌面人APP
本公众号可查看各种网课答案,还可免费查看大学教材答案
点击这里,可查看公众号功能介绍
APP下载
APP功能说明
1.可查看各种网课答案
点击【萌面人官网】,可查看知到智慧树,超星尔雅学习通,学堂在线等网课答案
点击【中国大学慕课答案】,可查看mooc慕课答案
2.可一键领取淘宝/天猫/京东/拼多多无门槛优惠券
如图所示,点击对应图标即可领取淘宝/天猫/京东/拼多多无门槛优惠券
拧萌闺累迹豌围硼乒围骄舒棘