蓝莓题库

中国大学moocc语言程序设计试题及答案-k8凯发

欢迎来访!

k8凯发-凯发官网入口慕课答案 正文

作者2022-12-05 16:23:40慕课答案 78 ℃0 评论
第一周:函数(一)

1.1 函数定义随堂测验

1、c语言是由( )构成。
    a、主程序和子程序
    b、主函数和子函数
    c、一个主函数和若干功能函数
    d、主函数和子程序

2、以下对c语言函数的有关描述中,正确的是( )。
    a、调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参
    b、c函数既可以嵌套定义又可以递归调用
    c、函数必须有返回值,否则不能使用函数
    d、c程序中有调用关系的所有函数必须放在同一个源程序文件中

3、以下说法中正确的是( )。
    a、c语言程序总是从第一个的函数开始执行
    b、在c语言程序中,要调用的函数必须在main()函数中定义
    c、c语言程序总是从main()函数开始执行
    d、c语言程序中的main()函数必须放在程序的开始部分

1.1 函数定义随堂测验

1、c语言程序中,如果变量做函数参数,则当函数调用时( )。
    a、实参和形参各占一个独立的存储单元
    b、实参和形参共用一个存储单元
    c、可以由用户指定是否共用存储单元
    d、计算机系统自动确定是否共用存储单元

2、一个函数返回值的类型是由( )决定的。
    a、return语句中表达式的类型
    b、在调用函数时临时指定
    c、定义函数时指定的函数类型
    d、调用该函数的主调函数的类型

3、在c语言的函数中,下列正确的说法是( )。
    a、必须有形参
    b、形参必须是变量名
    c、可以有也可以没有形参
    d、数组名不能作形参

1.4 函数间参数传递随堂测验

1、若函数的形参为一维数组,则下列说法中正确的是( )。
    a、调用函数时的对应实参必为数组名
    b、形参数组可以不指定大小
    c、形参数组的元素个数必须等于实参数组的元素个数
    d、形参数组的元素个数必须多于实参数组的元素个数

2、若调用一个函数,且此函数中没有return语句,则正确的说法是( )。
    a、该函数没有返回值
    b、该函数返回若干个系统默认值
    c、该函数能返回一个用户所希望的函数值
    d、该函数返回一个不确定的值

3、在函数的说明和定义时若没有指出函数的类型,则( )。
    a、系统自动地认为函数的类型为整型
    b、系统自动地认为函数的类型为字符型
    c、系统自动地认为函数的类型为实型
    d、编译时会出错

4、下面叙述中正确的是( )。
    a、对于用户自己定义的函数,在使用前必须加以说明
    b、说明函数时只需要说明返回类型
    c、函数必须返回一个值
    d、空函数不完成任何操作,所以在程序设计中没有用处

5、c语言允许函数返回值类型缺省定义,此时该函数隐含的返回值类型是( )。
    a、float型
    b、int 型
    c、long 型
    d、double型

第一周编程作业

1、求最大公约数和最小公倍数

2、排序并插入

第二周:函数(二)

2.1 函数递归调用随堂测验

1、在下列结论中,有一个是错误的,它是 ( )
    a、c语言允许函数的递归调用
    b、有些递归程序是不能用非递归算法实现的
    c、c语言不允许在函数定义中再定义函数
    d、递归函数就是函数中可以定义其他函数

2、如果有个递归函数是求 2*4*6*……*(2n) 的积,则递归的公式和条件可以表达为( )
    a、f(n)=2*n*f(n-1) 边界条件 当 n==1 f(n)=2
    b、f(n)=2*f(2*n-1) 边界条件 当 n==0 f(n)=1
    c、f(n)=2*nf(2*n-1) 边界条件 当 n==1 f(n)=1
    d、f(n)=2*f(2*n-1) 边界条件 当 n==0 f(n)=2

2.1 函数递归调用随堂测验

1、一段楼梯有n阶,可以一次上1阶,也可以一次上2阶,用递归函数调用实现,计算多少种走法。则递归公式和边界条件是( )
    a、f[n]=f[n-1] f[n-2] 边界条件 当n=1 f[1]=0, 当n =2 f[2]=1
    b、f[n]=f[n-1] f[n-2] 边界条件 当n=1 f[1]=1, 当n =2 f[2]=2
    c、f[n]=f[n-1] 边界条件 当n=1 f[1]=1
    d、f[n]= f[n-2] 边界条件 当n=2 f[2]=1

2、一只小猴子,摘了一堆水果,第一天吃了水果的一半,又多吃了一个;第二天吃了剩下水果的一半,又多吃了一个;依次类推….到第十天,发现只剩下了10个水果,请问这只猴子到底摘了多少个水果? 写成递归函数。
    a、
    b、
    c、
    d、

第二周编程作业

1、最大公约数

2、奇数求和

第三周:函数(三)

3.1 变量存储属性随堂测验

1、在一个c源程序文件中,若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是( )
    a、extern
    b、register
    c、auto
    d、static

2、如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为( )
    a、静态变量
    b、动态变量
    c、外部变量
    d、内部变量

3.1 变量存储属性随堂测验

1、以下程序的输出结果是: int f(int a) { auto int b=0; static int c=3; b ;c ; return a b c; } main( ) {int c,a=1; for(c=1;c<3;c ) printf(“= ”,f(a));}
    a、5 5
    b、5 6
    c、6 6
    d、6 7

2、以下程序的输出结果是: void fun(int *s) { static int j=0; do s[j] =s[j 1]; while( j<2); } main( ) { int k,a[10]={1,2,3,4,5}; for (k=1; k<3; k ) fun(a); for (k=0; k<5; k ) printf(“%d”,a[k] ); }
    a、34756
    b、23445
    c、35745
    d、12345

3.2 编译预处理随堂测验

1、以下程序的输出结果是: #define add(x) x x main( ) { int m=1,n=2,k=3,sum; sum=add(m n)*k; printf(“sum=%d\n”,sum); }
    a、sum=9
    b、sum=10
    c、sum=12
    d、sum=18

2、以下程序的输出结果是: #define n 1 #define m n 2 #define num 2*m 1 main( ) { int i; for (i=1; i<=num; i ) printf(“= ”, i ); }
    a、1 2 3 4 5
    b、1 2 3 4 5 6 7
    c、1 2 3 4 5 6
    d、程序出错

3、已知宏定义 #define n 3 #define y(n) ((n 1)*n) 执行语句z=2*(n y(5 1));后,z的值是( )。
    a、42
    b、48
    c、52
    d、出错

第三周编程作业

1、巧算自然数

2、卖鸭子

3、输出各位数字之和

第四周:指针(一)

4.1 指针的定义、初始化和引用随堂测验

1、若有说明:int *p1, *p2,m=5,n;以下均是正确赋值语句的选项是 。
    a、p1=&m; p2=&p1;
    b、p1=&m; *p2=*p1
    c、p1=&m; p2=p1;
    d、p1=&m; *p1=*p2;

2、以下叙述中正确的是 。
    a、指针定义后,可以指向同类型的任何变量。
    b、指针定义后,可以指向任何类型变量。
    c、指针定义后,可以用整型数据为指针初始化。
    d、指针定义后,只能指向一个变量。

3、变量的指针,其含义是指该变量的 。
    a、值
    b、地址
    c、名
    d、一个标志

4.2 指针与数组随堂测验

1、如果有定义int a[30], *p=a; 则数组a中下标为i的元素的地址为 。
    a、p i*2
    b、p (i-1)*2
    c、p (i-1)
    d、p i

2、若有如下定义,则________是对数组元素的正确的引用。 int a[10] , *p=a;
    a、*&a[10]
    b、*&a[0]
    c、*(p-11)
    d、*(a 11)

3、若有定义:int x[10]={0,1,2,3,4,5,6,7,8,9},*p1;则数值不为3的表达式是 。
    a、x[3]
    b、p1=x 3,*p1
    c、p1=x 2,*(p1 )
    d、p1=x 2,* p1

4.2 指针与数组随堂测验

1、下面函数的功能是 。 strlen1(char *s ) { char *p=s; while(*p!=‘\0’) p ; return p-s; }
    a、字符串反向
    b、字符串比较
    c、字符串连接
    d、字符串求长度

2、已知int a[ ]={1,3,5,7},y,*p=a;为了使变量y的值为3,下列语句正确的是 。
    a、y= *p ;
    b、y= (*p );
    c、y=( *p) ;
    d、y=(* p) ;

3、下面函数的功能是 。 void ( char *s1, char *s2) { while(*s2 =*s1 ); }
    a、字符串反向
    b、字符串比较
    c、字符串连接
    d、字符串复制

第四周编程作业

1、对称字符串

2、排序

3、查找数

第五周:指针(二)

5.1 指针与字符串随堂测验

1、运行以下程序时输入hello world( 代表enter 键),则输出的结果是( ) #include "stdio.h" char fun ( char *c ) { if ( *c < = 'z' & & *c > = 'a') *c - ='a'-'a'; return *c; } int main( ) { char s[81] , *p=s; gets(s); while(*p) { *p=fun(p); putchar(*p); p ; } putchar ( “ \n “ ); return 0; }
    a、hello world
    b、hello world
    c、hello world
    d、hello world

2、以下程序输出的结果是( ) #include " stdio.h" #include "string.h" void fun ( char *w, int m ) { char s, *p1 , *p2 ; p1=w; p2=w m-1; while(p1    a、7654321
    b、1711717
    c、1711771
    d、7177171

3、库函数strcpy用以复制字符串。若有以下定义和语句: char str1[ ]="greeting",str2[8],*str3,*str4="greeting"; 则对库函数strcpy的不正确调用是 ( )
    a、strcpy(str2,"hello2");
    b、strcpy(str3,"hello3");
    c、strcpy(str4,"hello4");
    d、都不正确

5.2 多维数组指针随堂测验

1、下面程序的运行结果是( ) int main( ) { int aa[3][3]={{2},{4},{6}},i,*p=&aa[0][0]; for(i=0;i<2;i ) { if(i==0) aa[i][i 1]=*p 1; else p; printf("%d",*p); } printf("\n"); return 0; }
    a、23
    b、26
    c、33
    d、36

2、若有定义语句int (*p)[m]; 其中的标识符是( )
    a、m个指向整型变量的指针
    b、指向m个整型变量的函数指针
    c、一个指向具有m个整型元素的一维数组指针
    d、具有m个指针元素的一维指针数组,每个元素都只能指向整型量

3、下面程序的运行结果是( ) int main( ) { int a[3][4]={1,3,5,7,9,11,13,15,17,19,21,23}; int (*p)[4]=a,i,j,k=0; for(i=0;i<3;i ) for(j=0;j<2;j ) k =*(*(p i) j); printf("%d\n",k); return 0; }
    a、60
    b、68
    c、99
    d、108

第五周编程作业

1、输出指定学生成绩

2、成绩排序

第六周:指针(三)

6.1指针与函数随堂测验

1、以下程序的输出结果是(): #include int funa(int a, int b) { return a b;} int funb(int a, int b) { return a-b;} int sub (int(*t)(int ,int ), int x, int y) { return (*t)(x,y);} int main( ) { int x,(*p)(int,int); p=&funa; x=sub(p,9,3); x =sub(&funb,8,3); printf("%d\n",x); }
    a、12
    b、15
    c、17
    d、19

2、若有以下说明和定义,则对fun函数的正确调用语句是( ) int main( ) { int (*a)(int*),*b( ),w[10],c; : : return 0; } int fun(int *c) {...}
    a、a=fun; a(w);
    b、a=fun; (*a)(&c);
    c、b=fun; *b(w);
    d、fun(b);

3、以下程序的输出结果是( ):void fun (int n,int *s) { int f1,f2; if (n==1||n==2) *s=1; else { fun(n-1,&f1); fun(n-2,&f2); *s=f1 f2; } } int main( ) { int x; fun(6,&x); pirntf("%d\n",x); return 0; }
    a、4
    b、6
    c、8
    d、12

6.2指针与指针随堂测验

1、下面程序运行结果( ): int main( ) { char ch[2][5 ] = {"6937","8254"} , *p[2]; int i , j , s = 0 ; for ( i=0 ; i <2 ; i ) p[i]=ch[i]; for ( i=0 ; i<2 ; i ) for( j=0 ; p[i][j]>'\0' &&p[i][j]<='9';j =2) s=10*s p[i][j]-'0'; printf("%d\n",s); return 0; }
    a、6385
    b、69825
    c、63825
    d、693825

2、以下程序的输出结果是( ): int main( ) { char *p[ ]={"program","basic","c","java"}; int i; for (i=3;i>=0;i--,i--) printf("%c",*p[i]); printf("\n"); return 0; }
    a、jvcbspo
    b、java
    c、jb
    d、javabasic

3、以下程序运行结果是( ): int main( ) { char *alpha[6]= {"abcd","efgh","ijkl","mnop","qrst","uvwx"}; char **p; int i; p=alpha; for( i=0; i<6; i=i 2 ) printf("%s",*(p i)); printf("\n"); return 0; }
    a、acegikmnqsuw
    b、aiq
    c、abcdijklqrst
    d、aeimqu

第六周编程作业

1、统计字符串出现次数

2、成绩统计

第七周:链表(一)

7.1 结构的概念随堂测验

1、以下定义错误的是( )。
    a、struct c { int x; int y; }s;
    b、struct { int x; int y; }s;
    c、struct c s { int x; int y; };
    d、struct c { int x; int y; }; struct c s;

2、当定义一个结构体变量时,系统为它分配的内存空间是( )。
    a、结构中一个成员所需的内存容量
    b、结构中第一个成员所需的内存容量
    c、结构中占内存最大的成员所需的内存容量
    d、结构中各成员所需内存容量之和

7.2 结构数组随堂测验

1、定义以下结构体类型 struct c { int x; float y; }a[3] sizeof(a)的结果是 ( )。
    a、4
    b、12
    c、18
    d、6

2、定义以下结构体数组 struct c { int x; int y; }s[2]={1,3,2,7} 语句printf(“%d”,s[0].x*s[1].x)的输出结果为( )。
    a、14
    b、6
    c、2
    d、21

7.3 结构指针随堂测验

1、有以下程序段 struct st { int x; int *y;}*pt; int a[] = {1,2}; int b[] = {3,4}; struct st c[2]={10,a,20,b}; pt=c; 以下选项中表达式为11的是( )。
    a、*pt->y
    b、pt->x
    c、 pt->x
    d、(pt )->x

2、运行下列程序段,输出结果是()。 struct country { int num; char name[10]; }x[5] = {1,”china”,2,”usa”,3,”france”,4,”england”,5,”spanish”}; struct country *p; p= x 2; printf(“%d,%c”,p->num,(*p).name[2]);
    a、3,a
    b、4,g
    c、2,u
    d、5,s

7.4 结构与函数随堂测验

1、以下哪种方式进行结构体数据的传递是错误的( )?
    a、通过结构体变量成员的引用
    b、通过结构体变量的引用
    c、通过结构体类型的引用
    d、通过结构体变量的指针

7.5 联合随堂测验

1、以下说法错误的是( )。
    a、联合与结构的引用方法是一样的
    b、联合与结构的定义除了关键字以外都是一样的
    c、联合与结构的初始化方法是一样的
    d、联合与结构的内存占用与成员内存占用间的关系是不一样的

第七周编程作业

1、学生成绩

第八周:链表(二)

8.1 typedef自定义类型随堂测验

1、设有如下说明 typedef struct data { int a; long b;} old; 则下列叙述中正确的是( )
    a、以上说明形式非法
    b、old是一个结构体类型
    c、old是一个结构体变量
    d、data是一个结构体变量

2、有如下说明typedef int(*p)[9],p的含义是( )
    a、一个指针
    b、一个数组
    c、一个指向数组的指针
    d、一个指针数组

8.2 枚举类型随堂测验

1、定义以下枚举类型 enum name {zhang = 2,wang = 4,li = 6,chen}; 则枚举量chen的值为( )
    a、0
    b、1
    c、7
    d、8

2、下面程序输出结果是( ) #include main() { enum name{ a, b = 2, c, d = c 10}; printf(“%d %d %d %d”, a,b,c,d);}
    a、1 2 3 4
    b、0 1 2 3
    c、0 2 3 13
    d、编译出错

8.3 链表的概念随堂测验

1、下述哪一条是顺序存储结构的优点?( )
    a、存储密度大
    b、插入运算方便
    c、删除运算方便
    d、可方便地用于各种逻辑结构的存储表示

2、链表不具有的特点是( )
    a、插入、删除不需要移动元素
    b、可随机访问任一元素
    c、不必事先估计存储空间
    d、链表空间可以减小

8.4 链表的基本操作随堂测验

1、在一个以 h 为头的单循环链中,p 指针指向链尾的判断条件是( )
    a、p^.next=nil
    b、p^.next.^next=h
    c、p^.next=h
    d、p^.data=-1

2、非空的循环单链表head的尾结点p↑满足( )。
    a、p↑.link=null
    b、p↑.link=head
    c、p=null
    d、p= head;

3、在单链表指针为p的结点之后插入指针为s的结点,正确的操作是:( )。
    a、p->next=s; s->next=p->next;
    b、s->next=p->next; p->next=s;
    c、p->next=s; p->next=s->next;
    d、p->next=s->next; p->next=s;

第九周 文件

9.1 文件概述随堂测验

1、关于文件理解不正确的为( )
    a、c语言把文件看作是字节的序列,即由一个个字节的数据顺序组成;
    b、每个打开文件都和文件结构体变量相关联,程序通过该变量中访问该文件;
    c、所谓文件一般指存储在外部介质上数据的集合;
    d、系统自动地在内存区为每一个正在使用的文件开辟一个缓冲区;

2、关于二进制文件和文本文件描述正确的为( )
    a、文本文件把每一个字节放成一个ascii代码的形式,只能存放字符或字符串数据;
    b、二进制文件把内存中的数据按其在内存中的存储形式原样输出到磁盘上存放;
    c、二进制文件可以节省外存空间和转换时间,不能存放字符形式的数据;
    d、一般中间结果数据需要暂时保存在外存上,以后又需要输入内存的,常用文本文件保存;

9.2 文件型指针随堂测验

1、系统的标准输入文件操作的数据流向为
    a、从键盘到内存
    b、从显示器到磁盘文件
    c、从硬盘到内存
    d、从内存到硬盘

2、文件指针指向的概念正确的是
    a、文件数据在硬盘的首地址
    b、文件数据在内存的首地址
    c、文件缓冲区结构的首地址
    d、文件路径名的首地址

9.3 文件的打开与关闭随堂测验

1、若要用fopen函数打开一个新的二进制文件,该文件要既能读也能写,则文件方式字符串应是
    a、"ab "
    b、"wb "
    c、"rb "
    d、"ab"

2、利用fopen (fname, mode)函数实现的操作不正确的为
    a、正常返回被打开文件的文件指针, 若执行fopen函数时发生错误则函数的返回null;
    b、以缓冲区方式打开一个文件;
    c、若找不到由fname指定的相应文件,则按指定的名字建立一个新文件;
    d、调用操作系统提供的打开或建立新文件功能;

9.4 文件的顺序读写随堂测验

1、函数fgets (char s[], int size, file* fp)的说法正确的是
    a、该函数最多可以一次读取size个字符组成的字符串
    b、读取正确则返回字符数组的首地址
    c、读取过程中遇到’\n’结束
    d、读取过程中遇到eof结束

2、利用fwrite (buffer, sizeof(student),3, fp)函数描述不正确的
    a、将3个学生的数据块按二进制形式写入文件
    b、将由buffer指定的数据缓冲区内的3* sizeof(student)个字节的数据写入指定文件
    c、返回实际输出数据块的个数, 若返回0值表示输出结束或发生了错误;
    d、若由fp指定的文件不存在,则返回0值

9.5 文件的随机读写随堂测验

1、若fp为文件指针,且文件已正确打开,i为long型变量,以下程序段的输出结果是。 fseek(fp, 0, 2); i=ftell(fp); printf("i=%ld\n", i);
    a、–1
    b、fp所指文件的长度,以字节为单位
    c、0
    d、2

2、以下操作正确的情况下,指针不能确保指在首地址的是
    a、rewind(fp)
    b、fopen(fname,fp,"r ")
    c、fseek(fp,0,0)
    d、ftell(fp)

9.6 文件检测随堂测验

1、检查由fp指定的文件在读写时是否出错的函数是
    a、feof(fp)
    b、eof==getc(fp)
    c、clearerr(fp)
    d、ferror(fp)

第九周编程作业

1、解析字符串

2、字符串的输入与反向显示

猜你喜欢

  • 2022-12-05 21:06
  • 2022-12-05 21:05
  • 2022-12-05 20:46
  • 2022-12-05 20:45
  • 2022-12-05 20:35
  • 2022-12-05 20:19
  • 2022-12-05 20:16
  • 2022-12-05 20:05
  • 2022-12-05 20:00
  • 2022-12-05 19:40
网站分类
最新发表
标签列表
网站地图