c语言程序设计中国大学mooc完整答案-买球的app软件下载

当前位置:正规买球app首页 » » 正文

6966 人参与  2023-01-04 05:22:56    点这评论
第1周——初识c语言从认识变量和常量开始

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

1、#include
    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周测验

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
    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、#abc123
    d、123abc
    e、o*k
    f、a?
    g、a b
    h、%a
    i、b!

2、以下不适合定义为用户标识符的是
    a、float
    b、main
    c、define
    d、_3com_
    e、pi
    f、source
    g、abc

3、#include
    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、hello world!

2、在屏幕上输出多行信息

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 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 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 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 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 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 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();
    b、magic=rand() 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 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
    b、#include
    c、#define
    d、#define

17、十进制3位数整数x,下面哪条语句能正确分离出它的十位上的数字d?
    a、d=(x-(x/100)*100)/10;
    b、d=(x0)/10;
    c、d=(x/10);
    d、d=x;
    e、d=(x-x)/10;
    f、d=x0;

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
    b、#include
    c、#define
    d、#define

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 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();
    b、magic=rand() 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 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=(x0)/10;
    c、d=(x/10);
    d、d=x;
    e、d=(x-x)/10;
    f、d=x0;

10、在c语言中对下面的语句而言,哪个说法是错误的? int a, b;
    a、变量a和b中的值都是0
    b、变量a和b中都没有数值
    c、变量a和b中的值都是未知的随机数
    d、a和b都是整型变量
    e、变量a和b占用的内存空间的大小是相同的

11、下列程序的输出结果是#include 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 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 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 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 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、存款利率计算器v1.0

3、数位拆分v1.0

4、求正/负余数

5、身高预测

6、求一元二次方程的根

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

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

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

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

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

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

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

第3周测验

1、分析下列程序,写出程序运行结果 #include int main() { char c1 = 'a', c2 = 'b', c3 = 'c'; printf("a���bc\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 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 int main() { int a,b,s; scanf("--",&a,&b); s=a/b; printf("s=%d",s); return 0; }
    a、1
    b、1.6875
    c、2
    d、0

5、以下程序的输出结果为 #include 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 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 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("--",&a,&b); printf("a=%d,b=%d",a,b);
    h、int a,b; scanf("%d,%d",&a,&b); printf("a=-,b=-",a,b);
    i、int a,b; scanf("a=%d,b=%d",&a,&b); printf("a=%d,b=%d",a,b);

11、程序运行后的输出结果是#include int main() { int a=666,b=888; printf("%d\n",a,b); return 0; }
    a、666
    b、错误信息
    c、888
    d、666,888

12、有以下语句段#include 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

13、以下选项中合法的字符常量是
    a、'\010'
    b、"b"
    c、68
    d、d

14、写出下面程序的输出结果#include 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 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 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 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 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、以上均不对

20、以下程序运行后的输出结果是 #include 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 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 int main() { int a=1234; printf("-\n",a); return 0; }
    a、1234
    b、12
    c、34
    d、提示出错、无结果

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

1、以下程序的输出结果为 #include 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 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 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 int main() { int a,b,s; scanf("--",&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 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 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 int main() { int a=1234; printf("-\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 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 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 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 int main() { char c1 = 'a', c2 = 'b', c3 = 'c'; printf("a���bc\n", c1, c2, c3); return 0; }
    a、aabbccabc
    b、acbcabc
    c、aabcabc
    d、acbbcabc

17、以下程序的输出结果为#include 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 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("--",&a,&b); printf("a=%d,b=%d",a,b);
    h、int a,b; scanf("%d,%d",&a,&b); printf("a=-,b=-",a,b);
    i、int a,b; scanf("a=%d,b=%d",&a,&b); printf("a=%d,b=%d",a,b);

20、写出下面程序的输出结果#include 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 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 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、网购打折商品v1.0

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

1、日期显示

2、产品信息格式化

3、计算两个数的平方和

4、拆分英文名

5、计算体指数

第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,即修改代码后需要进行回归测试。

第4周测验

1、程序代码如下:#include 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 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 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

3、从键盘输入三角形的三边长为a,b,c,按下面公式计算并输出三角形的面积。 程序代码如下,但程序运行后输出结果不正确,请找出有问题的语句。 #include #include 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);

4、编程设计一个简单的计算器程序,要求用户从键盘输入如下形式的表达式: 操作数1 运算符op 操作数2 然后,计算并输出表达式的值 指定的运算符为: 加( ) 减(-) 乘(*) 除(/) 代码如下,所给程序是否存在错误,若有,找出错误所在并改正。 #include 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 #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);

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 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 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

9、执行以下程序后的输出结果为 #include 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 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

11、下面程序代码的功能是判断输入整数的正负性和奇偶性,请将第19行和22行标号处缺少的代码填写完整。 #include 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行标号处缺少的语句填写完整。 #include 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 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 #include 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)

15、以下程序运行后的输出结果是 #include int main() { int a=1,b=2,m=0,n=0,k; k=(n=b>a)||(m=a    a、1,0
    b、0,0
    c、0,1
    d、1,1

16、以下程序的功能是计算一元二次方程的根。代码如下,请将第10行标号处缺少的语句填写完整。 #include #include #include #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 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 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 int main() { int a=1,b=2,m=0,n=0,k; k=(n=b>a)||(m=a    a、1,0
    b、0,0
    c、0,1
    d、1,1

4、以下程序运行后的输出结果是 #include 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 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 #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 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 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 #include 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 #include #include #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 #include 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 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 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 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 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 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语句那样起到判断表达式真假的作用。

第4周编程题在线测试

1、分数比较

2、存款利率计算器v2.0

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

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

1、检测用户错误输入

2、闰年判断

3、程序改错v1.0

4、字符类型判断

5、快递费用计算

6、数位拆分v2.0

7、出租车计价

8、数据区间判断

9、计算一元二次方程的根v2.0

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

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

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

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

1、下列说法错误的是()。
    a、函数rand()用于生成一个[0,rand_max]间的随机数,rand_max是不大于双字节整数的最大值32767的宏常量。使用函数rand()必须在程序开头加上这样一条编译预处理指令:#include
    b、magic = rand()0 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、运行时错误是指在程序运行时发生的错误,运行时错误有两种:一种是导致程序的运行结果与预期的不一致,另一种是导致程序无法正常运行。

第5周测验

1、程序运行后的输出结果是 #include 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 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

4、下面程序的输出是 #include 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

5、爱因斯坦数学题。爱因斯坦曾出过这样一道数学题:有一条长阶梯,若每步跨2阶,最后剩下1阶;若每步跨3阶,最后剩下2阶;若每步跨5阶,最后剩下4阶;若每步跨6阶,最后剩下5阶;只有每步跨7阶,最后才正好1阶不剩。请问,这条阶梯共有多少阶? 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include 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 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 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

9、以下正确的描述是
    a、只能在循环体内和switch语句体内使用break语句
    b、continue语句的作用是结束整个循环的执行
    c、在循环体内使用break语句或continue语句的作用相同
    d、continue语句可以写在循环体之外

10、计算 直到最后一项的绝对值小于为止。‍ 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include #include 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 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 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、下面程序的功能是输出以下形式的图案,则在下划线处应填入的是 * *** ***** 中国大学mooc完整答案* #include 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 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中的奇数之和

16、以下程序的输出结果是 #include 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 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 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=i0 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 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;

21、以下程序运行时,从键盘输入:01<回车>,程序执行后的输出结果是 #include 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

22、华氏和摄氏温度的转换公式为c=5/9×(f-32)。式中,c表示摄氏温度,f表示华氏温度。要求:华氏0℉~300℉,每隔20℉输出一个华氏温度对应的摄氏温度值。‍ 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include 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 #include 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 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 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 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 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 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 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 #include 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 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 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 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 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 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 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、下面程序的功能是输出以下形式的图案,则在下划线处应填入的是 * *** ***** 中国大学mooc完整答案*#include 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 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=i0 1; if (i>100) break; }
    c、for( ; ;);
    d、unsigned int k=0; do{ k; } while (k>=0);

19、计算 直到最后一项的绝对值小于为止。 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。#include #include 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 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 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 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 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;

第5周编程题在线测试

1、马克思手稿中的趣味数学题

2、猜神童年龄

3、闰年相关的问题v3.0——计算有多少闰年

4、闰年相关的问题v4.0——计算心跳数

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

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

2、奖金计算

3、程序修改—1

4、程序修改—2

5、程序改错-1

6、程序改错-2

7、程序改错-3

8、猴子吃桃程序_扩展1

9、猴子吃桃程序_扩展2

10、6位密码输入检测

11、判断一个整型数据有几位v1.0

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

13、计算球的反弹高度

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

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

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

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

1、下面所列举的函数名正确且具有良好风格的是()
    a、2_abcd()
    b、getnumber()
    c、change_directory()
    d、chushihua@()

第6周测验

1、下列说法中正确的是
    a、函数原型是一条语句,不包括函数体。
    b、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。
    c、在c语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。
    d、函数只有一个返回值,所以不能有多个return语句。

2、以下程序有语法错误,有关错误原因的正确说法是 #include 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 int sub(int k,int n) { int a1,a2; a2=k/10; a1=k-a2*10; if(________________) { printf("m",k); n ; return n; } else return -1; } int main() { int n=0,k,m; for(k=10;k<100;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 #include 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(x>y) fun(x,y); else if(y>z) 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 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; i    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 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 _________________________; int main() { int m, k; _________; do{ printf("please input m,k (m>=k>0):"); 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    b、第2行: long factorial(unsigned int number) 第6行: double p 第11行: m    c、第2行: unsigned long factorial(int number) 第6行: int p 第11行: m    d、第2行: unsigned factorial(unsigned number) 第6行: int p 第11行: m
12、完全数,又称完美数或完数(perfect number),它是指这样的一些特殊的自然数,它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身。例如,6就是一个完全数,是因为6 = 1 2 3。请编写一个判断完全数的函数isperfect(),然后判断从键盘输入的整数是否是完全数。注意:1没有真因子,所以不是完全数。 代码如下,按要求在空白处填写适当的表达式或语句,使程序完整并符合题目要求。 #include #include 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    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
13、以下程序执行后输出结果是 #include int maxvalue(int x, int y) { return x>y? x:y; } int minvalue(int x,int y) { return x>y? 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 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 int maxvalue(int x, int y) { return x>y? x:y; } int minvalue(int x,int y) { return x>y? 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 #include 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    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
6、下列说法中正确的是
    a、函数原型是一条语句,不包括函数体。
    b、无论何种情况,只要把用户自定义的所有函数都放在main函数的前面,就可以不用写函数原型了。
    c、在c语言中,只有当实参与其对应的形参同名时,才共占同一个存储单元,此时形参值的变化会影响到实参的值。
    d、函数只有一个返回值,所以不能有多个return语句。

7、以下程序有语法错误,有关错误原因的正确说法是 #include 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 int sub(int k,int n) { int a1,a2; a2=k/10; a1=k-a2*10; if(________________) { printf("m",k); n ; return n; } else return -1; } int main() { int n=0,k,m; for(k=10;k<100;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 #include 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(x>y) fun(x,y); else if(y>z) 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 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; i    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 _________________________; int main() { int m, k; _________; do{ printf("please input m,k (m>=k>0):"); 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    b、第2行: long factorial(unsigned int number) 第6行: double p 第11行: m    c、第2行: unsigned long factorial(int number) 第6行: int p 第11行: m    d、第2行: unsigned factorial(unsigned number) 第6行: int p 第11行: m
第6周编程题在线测试

1、计算阶乘的和v2.0

2、素数求和

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

1、绘制金字塔

2、利用泰勒级数计算sinx的值

3、计算100~200之间的所有素数之和

4、编程计算a aa aaa … aa…a(n个a)的值

第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、静态局部变量和静态全局变量的生存期是相同的,但二者的作用域是不同的,而静态局部变量和自动变量的作用域都是局部的,但二者的生存期是不同的。

第7周测验

1、下列说法正确的是
    a、递归算法的执行过程可分为递推和回归两个阶段。在递推阶段,必须要有终止递归的情况。当满足递归终止条件时,即获得最简单情况的解以后,开始进入回归阶段,即递归返回阶段。
    b、基本条件是一个能控制递归过程结束的条件,是递归的出口,它本身不再使用递归的方式来定义。一般条件定义了递归关系,控制递归调用向着基本条件的方向转化。
    c、数学归纳法是递归的数学基础。
    d、形参也是局部变量,形参变量和实参变量的作用域是不同的,因此形参变量和实参变量同名时,二者互不干扰。
    e、全局变量破坏了函数的封装性,不能实现信息隐藏,依赖全局变量的函数很难在其他程序中复用,对于使用全局变量的程序维护也比较困难,因此建议尽量不用全局变量。
    f、函数既可以嵌套定义,也可以嵌套调用。
    g、局部变量与全局变量同名时,全局变量隐藏局部变量,即全局变量起作用,局部变量不起作用。
    h、用extern声明变量为外部变量的时候,编译器是对其分配内存的。
    i、静态局部变量和静态全局变量的生存期和作用域都是相同的。

2、以下程序运行后的输出结果是 #include 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 int fun(int a, int b) { if(a>b) 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 void bin(int x) { if (x/2 > 0) bin(x/2); printf("%d\n", x%2); } int main() { bin(12); return 0; }
    a、1 1 0 0
    b、0 0 1 1
    c、6 3 1 0
    d、6 3 1 1

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 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()进行了两次调用,若使程序的输出结果是: 2 6 请补充完整空白处缺少的代码。 #include 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    b、第7行: i<=x 第13行: static int x=0
    c、第7行: i    d、第7行: i<=x 第13行: int x=0

8、请给出程序的运行结果。 #include 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、0 0
    b、8 8
    c、4 4
    d、64 64

9、写出下面程序的运行结果。 #include int square(int i) { return i * i; } int main(void) { int i = 0; i = square(i); for ( ; i<3; 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 如果a>b,则a和b与a-b和b的最大公约数相同,即gcd(a, b) = gcd(a-b, b) 性质2 如果b>a,则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 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 int fun(int n) { if (n==1) return 1; else return fun(n-1) 1; } int main() { int i,j=0; for(i=1;i<3;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 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 void bin(int x) { if (x/2 > 0) bin(x/2); printf("%d\n", x%2); } int main() { bin(12); return 0;
    a、1 1 0 0
    b、0 0 1 1
    c、6 3 1 0
    d、6 3 1 1

2、子函数incre()的功能是,利用静态变量,使子函数的输出值能够随调用次数的增加依次为: 第1次调用,输出:的结果 第2次调用,输出:的结果 第3次调用,输出:的结果 ..... 在下面的程序中,对子函数incre()进行了两次调用,若使程序的输出结果是: 2 6 请补充完整空白处缺少的代码。#include 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    b、第7行: i<=x 第13行: static int x=0
    c、第7行: i    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 int fun(int n) { if (n==1) return 1; else return fun(n-1) 1; } int main() { int i,j=0; for(i=1;i<3;i ) j =fun(i); printf("%d\n",j); return 0; }
    a、3
    b、4
    c、2
    d、1

5、以下程序运行后的输出结果是#include 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 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 int fun(int a, int b) { if(a>b) 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 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 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、0 0
    b、8 8
    c、4 4
    d、64 64

14、写出下面程序的运行结果。#include int square(int i) { return i * i; } int main(void) { int i = 0; i = square(i); for ( ; i<3; 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 如果a>b,则a和b与a-b和b的最大公约数相同,即gcd(a, b) = gcd(a-b, b) 性质2 如果b>a,则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 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)

第7周编程题在线测试

1、递归法求和

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

1、递归法计算游戏人员的年龄

2、递归法计算两个数的最大公约数

第8周—— 一堆数据来了,你准备好了吗

8.1 数组的定义和初始化(43分)随堂测验

1、下列说法错误的是()。
    a、c语言中的二维数组在内存中是按列存储的。
    b、在c语言中,数组的下标都是从0开始的。
    c、在c语言中,不带下标的数组名代表数组的首地址,即第一个元素在内存中的地址。
    d、c89规定不能使用变量定义数组的大小,但是在访问数组元素时在下标中可以使用变量或表达式。

8.2 向函数传递一堆相同类型的数据(15分半)随堂测验

1、下列说法错误的是()。
    a、简单变量做函数参数时,是将实参的值传给形参,实参和形参在内存中占用不同的存储单元,因此形参值的改变不会影响实参。
    b、数组做函数参数时,是将实参数组的首地址传给形参,形参数组和实参数组在内存中共享相同的存储单元,因此对形参数组元素值的修改也就相当于是对实参数组元素值的修改。
    c、在声明函数的二维数组形参时,可省略数组第二维的长度,但不能省略数组第一维的长度。
    d、在声明函数的一维数组形参时,通常不指定数组的大小,而用另一个形参来指定数组的大小。

8.3 查找算法——众里寻他千百度(37分半)随堂测验

1、在计算一组数据的最大值之前,通常假设这组数据中的第一个数为最大,即用这组数据中的第一个数为存放最大值的变量初始化。

8.3 查找算法——众里寻他千百度(37分半)随堂测验

1、线性查找算法不要求数据表是已排好序的,而二分查找算法要求数据表是已排好序的。

8.3 查找算法——众里寻他千百度(37分半)随堂测验

1、二分查找算法就是先将表的中间位置记录的关键字与查找关键字相比较,如果两者相等,则查找成功,否则将表分成前、后两个子表,根据比较结果,决定查找前一子表还是后一子表。

第9周——指针:c语言世界中所向披靡的“金箍棒”

9.1 指针变量的定义、初始化及其解引用(19分)随堂测验

1、下列说法错误的是()。
    a、指针变量占用的内存单元字节数就是它所指向的变量所占用的内存单元字节数。
    b、指针变量指向的数据的类型,称为指针的基类型。指针变量只能指向同一基类型的变量。
    c、指针变量使用之前必须初始化,如果你不知道该用什么值对其进行初始化的话,那么就先用null对其进行初始化。使用未初始化的结果将是无法预知的。
    d、通过间接寻址运算符引用指针变量指向的变量的值,称为指针的解引用。

9.2 指针变量作函数参数(36分半)随堂测验

1、普通变量做函数参数,是将实参值的一个副本传给形参,而指针变量做函数参数是将变量的地址值传给形参,因此你想要修改哪个变量的值,将这个变量的地址传给指针形参就好了。

9.3 进阶:函数指针及其应用(27分)随堂测验

1、int (*f)(int, int); 这条语句定义的是一个函数指针f,它可以指向一个有两个整型形参和整型返回值的函数。假设 int fun(int a, int b); 那么必须用f=fun();对f进行初始化,让其指向函数fun()。

9.4 进阶:数组的趣味应用(50分)随堂测验

1、筛法求素数的核心操作就是在一个按a[2]=2,a[3]=3,......,a[n]=n初始化的数组中依次筛掉所有素数的倍数。

9.4 进阶:数组的趣味应用(50分)随堂测验

1、void makedigit(int a[]) { int i, j, temp; srand(time(null)); for (i=0; i<10; i ) { a[i] = i; } for (i=0; i<10; i ) { j = rand() % 10; temp = a[j]; a[j] = a[i]; a[i] = temp; } }这个方法其实就是模拟了洗牌的方法对一个有序的数组元素进行随机置乱。

第10周——字符串:c语言世界中的大力水手

10.1 字符串的存储与表示(28分)随堂测验

1、下列说法正确的是()。
    a、用双引号括起的一串字符是字符串常量,系统自动为其添加空字符'\0'作为字符串的结束标志。
    b、字符数组的最后一个元素必须是字符'0'才能表示一个字符串。
    c、char *pstr = "hello china";表示定义了一个指向字符串常量的字符指针变量。此时既可以修改pstr的值,也可以通过间接寻址的方法修改pstr指向的字符。
    d、char *pstr; scanf("%s", pstr); 这两条语句的作用就是将用户从键盘输入的字符串保存到字符指针变量pstr中。

10.2 字符串处理操作(15分)随堂测验

1、下列说法正确的是()。
    a、strlen()计算的是包含'\0'在内的字符串的长度。
    b、字符串不能使用赋值运算符整体复制,必须使用strcpy函数进行字符串的复制。strcpy(str2, str1);是将字符数组str2中的字符串复制到字符数组str1中。
    c、strcat(str2, str1);是将字符数组str2中的字符串连接到字符数组str1中的字符串的末尾,str1中的字符串末尾的空字符'\0'将被覆盖。
    d、字符串不能用关系运算符>,<,==直接比较大小,必须使用strcmp函数比较大小,当出现第一对不相等的字符时,就由这两个字符的ascii码值的大小来决定其所在字符串的大小。

10.3 向函数传递和从函数返回字符串(26分)随堂测验

1、向函数传递字符串,既可以用字符数组做函数参数,也可以用字符指针做函数参数,这两种方式都是传引用调用,就是将字符串的首地址、而非字符串中的全部字符传给形参。

10.3 向函数传递和从函数返回字符串(26分)随堂测验

1、函数返回值的类型既可以是字符指针,也可以是字符数组。

第11周——指针的孪生兄弟

11.1 指针的运算(8分)随堂测验

1、下列说法错误的是()。
    a、指针指向数组元素时,指针算术运算才有意义
    b、两个指针指向同一个数组时,指针相减才有意义
    c、指针的算术运算允许通过对指针变量重复自增来访问数组的元素
    d、p 就是将指针变量p加上一个字节

11.2 指针和一维数组间的关系(14分)随堂测验

1、当指针变量指向一维数组的时候,sizeof(数组名)和sizeof(指针变量名)的计算结果是相同的。

11.3 指针和二维数组间的关系(18分)随堂测验

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

11.4 进阶:指针数组及其应用(22分)随堂测验

1、char *country[] = {"america", "england", "australia", "china", "finland"}; 这条语句定义了一个字符指针数组country,并用初始化列表中的每个字符串的首地址为字符指针数组country的元素进行初始化,并不是将初始化列表中的字符串保存到字符指针数组中。

第12周——海陆空齐上阵:又来了一堆数据

12.1 结构体类型(13分)随堂测验

1、关键字typedef主要用于定义一种新的数据类型。

12.1 结构体类型(13分)随堂测验

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}};

12.2 结构体与数组的嵌套(7分)随堂测验

1、在一个结构体内可以包含另一个不同类型的结构体作为其成员。

12.3 结构体的相关计算和操作(19分)随堂测验

1、下列说法错误的是()。
    a、结构体类型所占内存的字节数就是结构体的每个成员类型所占内存字节数的总和。
    b、结构体在内存中所占的字节数不仅与所定义的结构体类型有关,还与计算机系统本身有关。
    c、计算结构体所占内存的字节数时,一定要使用sizeof运算符。
    d、内存对齐的主要目的就是为了提高内存的寻址效率。不同的系统和编译器,内存对齐方式可能会不同,是机器相关的。

12.3 结构体的相关计算和操作(19分)随堂测验

1、下列说法错误的是()。
    a、对结构体变量的成员的访问是通过名字并使用成员选择运算符来访问的。
    b、只能在相同类型的结构体变量之间进行赋值。
    c、可以使用==和!=来判定两个结构体相等或不等。
    d、对嵌套的结构体成员,必须以级联的方式来访问。

12.4 向函数传递一堆不同类型的数据(28分半)随堂测验

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;

12.4 向函数传递一堆不同类型的数据(28分半)随堂测验

1、下列说法错误的是()。
    a、用结构体变量做函数参数,是将整个结构体的所有成员的内容传给被调函数,因此在被调函数中对结构体内容的修改不影响原结构体变量。
    b、用结构体数组/结构体指针作函数参数的参数传递效率比用结构体变量做函数参数的参数传递效率要高。
    c、用结构体数组/结构体指针作函数参数,是复制结构体的首地址给被调函数,因此在被调函数中可以修改结构体指针所指向的结构体的内容。
    d、数组和结构体变量都不可以用做函数返回值的类型。

12.5 枚举类型和共用体类型有什么用(25分)随堂测验

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、和整型、实型、字符型一样,枚举类型也是一种基本数据类型。

12.5 枚举类型和共用体类型有什么用(25分)随堂测验

1、下列说法错误的是()。
    a、编译器只为共用体中最大的成员分配足够的内存空间。共用体的成员在这个空间内是彼此覆盖的,都从同一起始地址开始存储。
    b、与结构体不同的是,共用体在内存中所占空间的字节数取决于占空间最多的那个成员变量。
    c、共用体变量在每一瞬时只能保存一个成员,起作用的成员是最后一次赋值的成员。
    d、共用体和结构体的成员访问方式以及成员的初始化方式都是一样的,都使用成员选择运算符访问成员变量,都可以在定义的时候对所有成员进行初始化。

第13周——原来内存也可以这么玩,我是指针我怕谁

13.3 进阶:常见的内存错误及其解决对策(52分半)随堂测验

1、指针变量所占的内存被释放了,也就意味着它所指向的动态内存也会被自动释放。

2、用free释放指针变量所指向的内存以后,就意味着该指针变量变成了空指针。

第15周——学会保存你的数据

15.4 字符和字符串的文件读写(39分)随堂测验

1、函数fgetc()的功能是从fp所指的文件中读取一个字符,并将位置指针指向下一个字符。若读取成功,则返回该字符,若读到文件末尾或者读取出错,则返回eof。eof是一个符号常量,通常在stdio.h中定义为-1。

2、函数feof()的功能是检查是否到达文件尾,只要读完最后一个字符、文件位置指针指向文件尾时(eof)时,就会返回非0值,否则返回0值。

15.4 字符和字符串的文件读写(39分)随堂测验

1、fgets()与gets()的不同点是,gets()从指定的流读字符串,读到换行符时将换行符替换为'\0',读入的字符串中不会保留'\n',而fgets()从指定的流读字符串,读到换行符时不替换为'\0',读入的字符串中会保留'\n',在'\n'的后面会再添加一个'\0'。

2、fputs()是向任意流写数据,puts()是向标准输出流写数据,二者在写数据时的不同之处是,puts()会在写入的字符串末尾自动添加换行符,而fputs()不会在写入的字符串末尾自动添加换行符,除非字符串本身含有换行符。

下一篇 >>

相关文章

  • 2023-01-04 05:37
  • 2023-01-04 05:27
  • 2023-01-04 04:29
  • 2023-01-04 03:48
  • 2023-01-04 03:43

备案号: 买球平台网址的版权所有 买球平台网址 copyright © 2012-2023 青果答案 all rights reserved. sitemap