0.0687

五煦查题

快速找到你需要的那道考题与答案

尔雅C语言程序设计_88期末答案(学习通2023课后作业答案)

57 min read

尔雅C语言程序设计_88期末答案(学习通2023课后作业答案)

第1周——初识C语言从认识变量和常量开始

1.2 C 语言集成开发环境简介(16分钟)随堂测验

1、尔雅#include <stdio.h>是语言程
A、编译预处理指令
B、序设习通语句
C、计期函数
D、末答程序入口

1.2 C 语言集成开发环境简介(16分钟)随堂测验

1、案学codeblocks中运行到下一步(next line)的课后快捷键是
A、F7
B、作业F5
C、答案F8
D、尔雅F11

1.4 变量的语言程表数范围和存储形式(29分钟)随堂测验

1、C语言用sizeof计算变量在内存中的序设习通字节数,其中sizeof是计期()
A、函数
B、末答运算符
C、案学标识符
D、语句

1.5 宏常量与const常量(13分钟)随堂测验

1、宏定义是()
A、一条语句
B、一种编译预处理指令
C、一个标识符
D、一个变量

2、const常量有数据类型。

练兵区—不计入总分

1、下列选项中,合法的C语言标识符是
A、_a1
B、width.x
C、#abc123
D、123abc
E、o*k
F、a?
G、a+b
H、%a
I、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;

第2周——数字间的那些事儿,做点计算哈

2.1 算术运算(20分钟)随堂测验

1、二元的算术运算符的结合性都是左结合。

2.2 赋值运算(15分钟)随堂测验

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;

2.4 自动类型转换(5分钟)随堂测验

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

2.5 强制类型转换(7分半)随堂测验

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

第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.000000 2
B、18 2
C、18 2.000000
D、18.000000 2.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、#include <math.h>
B、#include <stdio.h>
C、#define <math.h>
D、#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、#include <math.h>
B、#include <stdio.h>
C、#define <math.h>
D、#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.000000 2
B、18 2
C、18 2.000000
D、18.000000 2.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、输出逆序数

2、计算总分和平均分

3、存款利率计算器V1.0

4、数位拆分v1.0

5、求正/负余数

6、身高预测

7、求一元二次方程的根

第3周——从键盘中来,到键盘中去,开始输入和输出啦

3.1 数据的格式化屏幕输出(15分钟)随堂测验

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

3.3 单个字符的输入输出(15分半)随堂测验

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

3.5 进阶:用%c输入数据存在的问题(含错误案例分析)(10分)随堂测验

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

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

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=10 n2=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、写出下面程序的输出结果#include<stdio.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=10 b=3, y=6
B、a=6, x=10 b=3, y=8
C、a=6, x=12 b=3, y=6
D、以上均不对

第3周-练兵区——编程题——不计入总分

1、日期显示

2、产品信息格式化

3、计算两个数的平方和

4、逆序数的拆分计算

5、拆分英文名

6、计算体指数

第4周——无处不在的抉择

4.1 关系运算符和逻辑运算符(23分钟)随堂测验

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

4.2 条件语句(14分钟)随堂测验

1、下列关于if-else语句的说法中哪个是正确的。
A、else总是和离它最近的if配对
B、else总是和前面离它最近的且还未和其他else匹配的在同一语句块内同一层次的if配对
C、else总是和前面离它最近的且位于花括号内的if配对
D、else可以和它前面的尚未与其他else匹配的任何一个if配对

2、条件运算符是C语言中唯一的一个三元运算符.

4.4 进阶:数值溢出和精度损失问题(34分半)随堂测验

1、在赋值操作中,当赋值表达式左侧的变量的类型与右侧的表达式的类型不一致的时候,下面说法正确的是()。
A、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,会发生自动类型转换,赋值表达式的结果类型是赋值运算符左侧变量的类型。
B、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,赋值表达式的结果类型是赋值运算符右侧表达式的类型。
C、在赋值操作中,只要赋值运算符左侧的变量的类型与右侧的表达式的类型不一致,就会发生数值溢出。
D、在赋值操作中,当赋值运算符左侧的变量的类型与右侧的表达式的类型不一致的时候,要么发生数值溢出,要么发生数值精度的损失。

4.4 进阶:数值溢出和精度损失问题(34分半)随堂测验

1、下列说法错误的是()。
A、浮点数并非真正意义上的实数,只是其在某种范围内的近似。
B、浮点数能精确表示的数字位数取决于这种类型的浮点数的有效数字位数。
C、使用更多的位来存储阶码,将会扩大浮点数的表数精度。
D、受浮点数表数精度的限制,因此对于浮点数不能直接比较其是否相等,应该比较其是否近似相等。

4.5 进阶:软件测试与错误实例分析(20分半)随堂测验

1、下列说法错误的是()。
A、软件测试的目的就是证明程序的正确性,即给定特定的输入,通过运行被测程序,检查程序的输出是否与预期结果一致,进而验证程序的正确性。
B、白盒测试就是在完全了解程序的结构和处理过程的情况下,按照程序内部的逻辑测试程序,检验程序中的每条逻辑路径是否都能按预定要求正确工作。黑盒测试就是把系统看成一个黑盒子,不考虑程序内部的逻辑结构和处理过程,只根据需求规格说明书的要求,设计测试用例,检查程序的功能是否符合它的功能说明。
C、在选择测试用例时,不仅要选取合理的输入数据,还要选取一些不合理的输入数据,以及某些极端的边界点或临界点等,对程序进行测试
D、由于修复了旧的bug的同时,往往又会产生新的bug,因此往往还需要对所有出现过的bug重新测试一遍,看其是否会重新出现,并给确认代码修改后没有引入新的bug,即修改代码后需要进行回归测试。

练兵区——单选题

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=b>a)||(m=a<b); 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%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

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行语句下方应加入 #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 = %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); //x<0,则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+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=%.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行标号处缺少的语句填写完整。#include<stdio.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",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

15、以下程序运行后的输出结果是#include <stdio.h> int main() { int a=5,b=4,c=3,d; d=(a>b>c); 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(a>b) { if(b>c) { 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、从键盘任意输入一个公元年份(大于等于1),判断它是否是闰年。若是闰年输出“Yes”,否则输出“No”。要求对输入数据进行合法性判断。已知符合下列条件之一者是闰年: (1)能被4整除,但不能被100整除; (2)能被400整除。

2、从键盘键入任意一个字符,判断该字符是英文字母(不区分大、小写)、数字字符还是其它字符。 若键入字母,则屏幕显示 It is an English character.;若键入数字则屏幕显示It is a digit character. ;若输入其它字符,则屏幕显示:It is other character.

3、从键盘上输入一个4位数的正整数n,编写程序将其拆分为两个2位数的整数a和b,计算并输出拆分后的两个数的加、减、乘、除和求余运算的结果。例如n=4321,设拆分后的两个整数为a,b,则a=43,b=21。除法运算结果要求精确到小数点后2位,数据类型为float。求余和除法运算需要考虑除数为0的情况,即如果拆分后b=0,则输出提示信息"The second operater is zero!"

第5周——周而复始的循环之道

5.1 计数控制的循环(31分钟)随堂测验

1、下列说法错误的是()。
A、逗号运算符也称为顺序求值运算符,由逗号运算符构成的表达式称为逗号表达式。
B、多数情况下,我们并不使用整个逗号表达式的值,主要用它来顺序求得到各个子表达式的值。
C、逗号表达式主要用在循环语句中同时对多个变量赋初值等。
D、在逗号表达式中,其第一个表达式的值就是整个逗号表达式的值。

5.3 条件控制的循环(32分钟)随堂测验

1、下列说法错误的是()。
A、函数rand()用于生成一个[0,RAND_MAX]间的随机数,RAND_MAX是不大于双字节整数的最大值32767的宏常量。使用函数rand()必须在程序开头加上这样一条编译预处理指令:#include <stdio.h>
B、magic = rand()%100 + 1用于生成[1,100]之间的随机数。
C、事实上,函数rand()产生的都是伪随机数。
D、函数srand()用于为rand()设置随机数种子,使rand()产生的随机数“随机化”。

5.4 嵌套循环(17分钟)随堂测验

1、下列说法错误的是( )。
A、执行嵌套循环时是先执行内层循环,后执行外层循环。
B、嵌套循环的内层和外层循环的循环控制变量不能同名。
C、嵌套循环的循环次数等于外层循环的循环次数与内层循环的循环次数之积。
D、如果一个循环的循环体中又完整地包含了另一个循环,则称为嵌套循环。

5.5 穷举(39分钟)随堂测验

1、下面程序段中的break语句是转移到哪里去执行()。for(...) { for(...) { switch(...) { case 1: ... break; case 2:... ... } A: //code } B: //code } C: //code
A、转到标号A所在的语句行与执行
B、转到标号B所在的语句行与执行
C、转到标号C所在的语句行与执行
D、不进行流程转移,而是继续执行break后面的语句

5.6 进阶:软件调试与错误实例分析(27分钟)随堂测验

1、下列说法错误的是()。
A、程序测试的目的就是验证程序的正确性。
B、程序中常见的错误有三种:编译错误,链接错误,以及运行时错误。
C、编译错误通常是由语法错误造成的。
D、运行时错误是指在程序运行时发生的错误,运行时错误有两种:一种是导致程序的运行结果与预期的不一致,另一种是导致程序无法正常运行。

循环结构-单选题

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); 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( ; y>0; 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;i<5;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;i<10;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;i<3;i++) { scanf("%c",&k); switch(k) { case '0': printf("another\n"); case '1': printf("number\n"); } } return 0; }
A、another number number
B、number number
C、another number
D、another number another

14、以下程序执行后的输出结果是#include <stdio.h> int main( ) { int x=0,y=5,z=3; while(z-->0 && ++x<5) { 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;n>1;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;

for语句练习

1、改进课件中例4:编写一个可以为小学生提供加法、减法和乘法的二元算术运算练习的程序,计算100以内的两个数的和、两个数的差和两个数的积,每次测试10个题目,依次由学生输入答案,并由计算机判断输入的答案是否正确,最后由计算机给出简单评价。 要求满足下面条件 (1)程序在结束了一组测试之后,可以继续进行测试; (2)增加两位数的除法(求商和余数)计算。

2、编写程序,在屏幕上输出下面的结果(每列数据按左对齐方式),输出数据的行数通过键盘输入,要求在5~20行之间。对于输入的行数进行可行性判断。 3 5 7 9 6 8 10 12 9 11 13 15 12 14 16 18 15 17 19 21

循环结构练习

1、判断一个整型数据有几位

2、程序修改—求n个自然数的和

3、程序修改—用while改写do-while结构

4、程序改错-百元买白鸡

5、6位密码输入检测

6、检测输入数据中奇数和偶数的个数

7、程序改错-素数的判定

第6周——函数:分工与合作的艺术

6.1 函数定义、调用、参数传递和函数原型(35分半)随堂测验

1、下列说法中错误的是()。
A、函数中的return语句可以有多个,但是多个return语句并不表示函数可以用return返回多个值,用return返回的函数值只能有一个。
B、在C语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。
C、形参也是局部变量,只能在函数体内访问。
D、在C语言中,实参与其对应的形参各占独立的存储单元,函数调用时的参数传递就是把实参的值复制一份给形参,即由实参向形参进行单向传值,因此形参值的变化不影响实参的值。

6.1 函数定义、调用、参数传递和函数原型(35分半)随堂测验

1、下列说法错误的是()。
A、当函数原型与函数定义中的形参类型不一致时,编译器一般都会指出参数类型不匹配的编译错误。因此,写上函数原型有助于编译器对函数参数进行类型匹配检查。
B、函数声明是一条语句,不包括函数体。
C、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。
D、函数调用时,要求实参与形参的数量相等,它们的类型也要匹配,匹配的原则与变量赋值的原则一致。当函数调用时的实参与函数定义中的形参的类型不匹配时,有的编译器会发出警告,提示有可能出现数据信息丢失,而有的编译器则不会发出警告。

6.2 函数封装与程序的健壮性(23分钟)随堂测验

1、下列说法错误的是()。
A、我们常将程序具有遇到不正确使用或非法数据输入时仍能保护自己避免出错的能力称为程序的健壮性。
B、在函数的入口处增加对函数参数合法性的检查以及对函数调用是否成功的检查,是一种常用的增强程序健壮性的方法。
C、对于一个封装好的函数,外界对函数的影响仅限于入口参数,函数对外界的影响仅限于函数的返回值和数组、指针形参 。
D、编译器给出的警告信息无关紧要,因此可以忽略。

6.3 进阶:断言与防御式编程(14分钟)随堂测验

1、下列说发错误的是()。
A、assert()其实是一个在<assert.h>中定义的宏,用来验证“不应该”发生的情况是否的确不会发生。
B、assert()的功能就是验证assert后括号内表达式值的真假,当该表达式的值为真时,它什么也不做。反之,则立即终止程序的执行,并报告错误,但是不会对错误采取其他处理措施。
C、在使用assert()时,必须在源文件中用编译预处理指令包含头文件<assert.h>。
D、断言不仅可以用于调试程序,还可以作为程序的功能,检查有可能发生的程序错误。

6.3 进阶:断言与防御式编程(14分钟)随堂测验

1、在下列哪些情况下适合使用断言?
A、检查程序中的各种假设的正确性。
B、证实或测试某种不可能发生的状况确实不会发生。
C、捕捉不应该或者不可能发生的非法情况。
D、捕捉程序中有可能出现的错误。

6.4 进阶:代码风格(22分钟)随堂测验

1、下面所列举的函数名正确且具有良好风格的是()
A、2_abcd()
B、GetNumber()
C、change_directory()
D、chushihua@()

第7周——《盗梦空间》的逻辑:探寻递归的奥秘

7.1 从嵌套调用到递归调用(20分钟)随堂测验

1、下列说法错误的是()
A、函数既可以嵌套定义,也可以嵌套调用。
B、函数直接或间接调用自己,称为递归调用。
C、一个递归算法必须包含一般条件和基本条件两个基本要素。
D、基本条件是一个能控制递归过程结束的条件,是递归的出口,它本身不再使用递归的方式来定义。一般条件定义了递归关系,控制递归调用向着基本条件的方向转化。

7.1 从嵌套调用到递归调用(20分钟)随堂测验

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

7.2 递归是如何执行的(16分钟)随堂测验

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

7.3 进阶:尾递归是什么鬼?(14分半)随堂测验

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

7.4 变量的作用域(22分半)随堂测验

1、下列说法错误的是()。
A、变量的作用域是指变量的作用范围,即在程序中可以被读写访问的区域,它取决于变量被定义的位置。
B、局部变量与全局变量同名时,全局变量隐藏局部变量,即全局变量起作用,局部变量不起作用。
C、形参也是局部变量,形参变量和实参变量的作用域是不同的,因此形参变量和实参变量同名时,二者互不干扰。
D、只要同名的变量出现在不同的作用域内,二者互不干扰,编译器有能力区分不同作用域中的同名变量

7.4 变量的作用域(22分半)随堂测验

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

7.5 进阶:变量的生存期(33分半)随堂测验

1、下列说法错误的是()。
A、变量的作用域决定了变量可以被访问的范围,而变量的存储类型决定了变量的生存期。
B、静态变量和全局变量都是在静态存储区中分配内存的,而自动变量是在动态存储区中分配内存的。
C、用extern声明变量为外部变量的时候,编译器是对其分配内存的。
D、静态局部变量和静态全局变量的生存期是相同的,但二者的作用域是不同的,而静态局部变量和自动变量的作用域都是局部的,但二者的生存期是不同的。

学习通C语言程序设计_88

作为一门计算机编程语言,C语言已经有超过40年的历史。其高效、简洁、功能强大的特点,使得C语言在计算机编程领域中得到广泛应用。在计算机程序设计入门阶段,学习C语言已经成为了必修课程,而学习通C语言程序设计_88就是一门非常优秀的C语言教程。

学习通C语言程序设计_88介绍

学习通C语言程序设计_88是由蒋宇航老师亲自授课录制的C语言教程。该教程包含了C语言的基础语法、算法、数据结构等方面的内容,同时也涵盖了C语言在实际编程中的应用。通过学习这门课程,学生可以全面掌握C语言的编程技巧和方法,为以后更深入的计算机编程学习打下坚实的基础。

学习通C语言程序设计_88的特点

学习通C语言程序设计_88具有以下特点:

  1. 内容全面:该教程的内容非常全面,从C语言的基础语法到数据结构和算法,再到C语言在实际应用中的技巧和方法,都有详细的讲解。
  2. 案例丰富:教程中提供了很多实际的编程案例,其中包括简单的小游戏、计算器、文件管理等等,这些案例可以帮助学生更好地理解和掌握C语言编程。
  3. 教学方法灵活:蒋宇航老师的教学方法非常灵活,他会根据不同学生的情况进行个性化的教学,帮助学生更好地理解和掌握C语言编程。
  4. 讲解清晰:蒋宇航老师的讲解非常清晰易懂,他能够将抽象的概念用生动的语言和具体的例子讲解清楚。

学习通C语言程序设计_88的课程设置

学习通C语言程序设计_88包含以下几个部分:

  1. 基础语法:包括数据类型、运算符、表达式、流程控制语句等。
  2. 函数和指针:包括函数的定义、调用、递归、指针的定义、指针的应用等。
  3. 数组和字符串:包括一维数组、二维数组、字符串的定义、字符串的应用等。
  4. 结构体和联合体:包括结构体的定义、结构体的应用、联合体的定义、联合体的应用等。
  5. 文件操作:包括文件的打开、读写文件、文件指针等。
  6. 高级应用:包括常见算法、数据结构、多文件编程等。

学习通C语言程序设计_88的学习方式

学习通C语言程序设计_88可以通过以下几种方式进行学习:

  1. 在学习通网站上观看视频课程和听取在线课程。
  2. 下载和使用相关课程资料和代码进行学习。
  3. 参加学习通组织的在线辅导。

总结

学习通C语言程序设计_88是一门非常优秀的C语言教程,其全面的课程设置、丰富的案例以及清晰易懂的讲解,可以帮助学生全面掌握C语言编程技巧和方法,为以后更深入的计算机编程学习打下坚实的基础。