电大计算机本科 C语言程序设计形成性作业(带答案)

更新时间:2024-05-01 21:04:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

C语言程序设计形成性作业一

一、 选择题

1. 在每个C语言程序中都必须包含有这样一个函数,该函数的函数名为(A)。

A.main B.MAIN C.name D.funtion 2.C语言原程序文件的缺省扩展名为(A)。

A.cpp B.exe C.obj D.C 3.由C语言目标文件连接而成的可执行的缺省扩展名为(B)。 A.cpp B.exe C.obj D.C

4.程序运行中需要从键盘输入多于一个数据时,各数据之间应使用(D)符号作为分隔符。

A.空格或逗号 B.逗号或回车 C.回车或分号 D.空格或回车

5.每个C语言程序的编译错误分为(B)类。 A.1 B.2 C.3 D.4 6.设x 和y 均为逻辑值,则x && y为真的条件是(A)。 A.它们均为真 B.其中一个为真 C.它们均为假 D.其中一个为假

7.设有语句“int a=12;a+=a*a;”,则执行结束后,a 的值为(C)。 A.12 B.144 C.156 D.288 8.x>0 && x<=10的相反表达式为(A)。

A.x<=0 || X>10 B.x<=0 && x>10 C.x<=0 || x<=10 D.x>0 && x>10 9.字符串“a+b=12\\n”的长度为(B)。

A.6 B.7 C.8 D.9

10.在下列符号常量定义中。错误的定义语句格式为(C)。 A.const M1=10; B.const int M2=20; C.const M3 10 D.const char mark=’3’;

11.带有随机函数的表达式rand() 的值在(C)区间内, A.1~19 B.1~20 C.0~19 D.0~20 12.当处理特定问题时的循环次数已知时,通常采用(A)循环来解决。 A.for B.while C.do-while D.switch 13.在switch语句的每个case块中,假定都是以break语句结束的,则此switch语句容易被改写为(B)语句。

A.for B.if C.do D.while 14.for语句能够被改写为(D)语句。

A.复合 B.if C.switch D.while 15.下面循环语句执行结束后输出的i值为(B)。 for(int i=0;in/2){cout<

A.n/2 B.n/2+1 C.n/2-1 D.n-1 16.在下面循环w语句中内层循环体S语句的执行次数为(D)。 for(int i=0;i

for(int j=i;j

A.n2 B.(n+1)/2 C.n(n-1)/2 D.n(n+1)/2 17.在下面的do循环语句中,其循环体被执行的次数为(A )。 int i=0;do i++;while(i*i<10);

A.4 B.3 C.5 D.2

二、填空题

1.C语言中的每条简单语句以___;_______作为结束符。 2.C语言中的每条复合语句以___}_______作为结束符。

3.在C语言程序的每个程序行后面或单独一行的开始使用注释的标记符为___//___。

4.单行或多行注释的结束标记符为__*/_____。

5.在一个C程序文件中,若要包含另外一个头文件或程序文件,则应使用以__#include___标识符开始的预处理命令。

6.在#include命令中所包含的头文件,可以是系统定义的头文件,也可以是__用户___定义的头文件。

7.一个函数定义由__函数头______和函数体两部分组成。 8.用于输出表达式的标准输出函数是_printf( )_________。

9.当不需要函数返回任何值时,则应使用__void_______标识符定义函数类型。 10.执行“printf(“%d-%d=%d”,43,18,43-18); ”语句后得到的输出结果为__43-18=25_______。

11.每个C程序文件在编译时可能出现有警告性错误,其对应的标识符为__warning______。

12.每个C程序文件在编译时可能出现有致命性错误,其对应的标识符为__error______。

13.十进制数25表示成符合C语言规则的十六进制数为___0x19___。 14.在C语言中,转义字符序列___\\n___表示一个换行符。

15.执行“printf(“%c”,’F’-2);”语句后得到的输出结果为__D___。 16.已知’A’~’Z’的ASCII码为65-90,当执行“int x=’C’+5;”语句所x的值为___72___.

17.假定一个枚举类型的定义为“enum RB{ab,ac=3,ad,ae}x=ad;”,则x的值为___4___.

18.char类型的大小为__1__个字节。 19.int类型的大小为__4__个字节。 20.float类型的大小为__4__个字节。 21.十进制数28类型为___int___。 22.十进制数3.26类型为___double___。

23.若需要定义一个符号常量,并且使C语言能够进行类型检查,则应在定义语句的开始使用保留字____const___。

24.使用const语句定义一个符号常量时,则必须对它同时进行__定义类型和赋初值__。

25.执行“int x=45,y=13;printf(“%d”,x%y);”语句序列后得到的输出结果为___6__。

26.假定x=5,则表达式2+x++的值为__7__。 27.表达式(float)25/4的值为___6.25___。 28.表达式(int)14.6%5的值为___4___。 29.表达式x=x+1表示成增量表达式为__x++___。 30.增量表达式++y表示成赋值表达式为___y+=1__。 31.关系表达式(x!=0)的等价表达式为____x___。

32.假定不允许使用逻辑非操作符,则关系表达式x+y>5的相反表达式为___x+y<=5__。

33.假定不允许使用逻辑非操作符,则逻辑表达式a>b || b==5的相反表达式为___a<=b && (b>5 || b<5)____。

34.若x=5,y=10,则x>y逻辑值为___false___。 35.若x=5,y=10,则x<=y逻辑值为___true___。

36.假定x=5,则执行“a=(x?10:20);”语句后a的值为__10__。

37.执行“typedef int DataType;”语句后,在使用int定义整型变量的地方都可以使用___DataType___来定义整型变量。

38.在switch语句中,每个语句标号所含保留字case后面的表达式必须是__整型__。

39.作为语句标号使用的C保留字case和default只能用于__switch__语句的定义体中。

40.在switch语句时,在进行作为条件的表达式求值后,将从某个匹配的标号位置起向下执行,当碰到下一个标号位置时(停止/不停止)___不停止__执行。 41.若do循环的“尾”为“while(++i<10)”,并且i的初值为0,同时在循环体不会修改i的值,由循环体将被重复执行__10___次后正常结束。

42.当在程序执行到___break___语句时,将结束本层循环语句或switch语句的执行。

43.在程序中执行到__return__语句时,将结束所在函数的执行过程,返回到调用该函数的位置。

44.在程序执行完__主(main)__函数调用后,将结束整个程序的执行过程,返回到操作系统或C语句集成开发环境界面窗口。

三、写出下列每个程序运行后的输出结果 1. #include void main() {

int x=5;switch(2*x-3){

case 4:printf(\ case 7:printf(\ case 10:printf(\ default:printf(\ }

printf(\

}

输出结果为: 11 14 switch end.

2. #include void main() {

int i,s=0; for(i=1;i<=6;i++) s+=i*i; printf(\}

输出结果为: s=91.

3. #include void main() {

int i,s1=0,s2=0; for(i=0;i<10;i++)

if(i%2)s1+=i;

else s2+=i;

printf(\}

输出结果为: 25 20.

4. #include void main() {

int n=10,y=1; while(n--){y++;y++;} printf(\}

输出结果为: y=21.

5. #include void main() {

int f,f1,f2,i; f1=f2=1;

printf(\

for(i=3;i<=10;i++){ f=f1+f2;

printf(\ if(i%5==0)printf(\ f1=f2; f2=f; }

printf(\}

输出结果为: 1 1 2 3 5 8 13 21 34 55

6. #include #include void main() {

int i,n;

for(n=2;n<=20;n++){

int temp=(int)sqrt(n);//sqrt(n)求出n的平方根并取整

for(i=2;i<=temp;i++)

if(n%i==0)break;

if(i>temp)printf(\ }

printf(\}

输出结果为: 2 3 5 7 11 13 17 19

7. #include #include const int M=20; void main() {

int i,c2,c3,c5; c2=c3=c5=0; for(i=1;i<=M;i++){

if(i%2==0)c2++; if(i%3==0)c3++; if(i%5==0)c5++; }

printf(\}

输出结果为: 10 6 4

8. #include #include const int M=20; void main() {

int i,s;

for(i=1,s=0;i<15;i++){

if(i%2==0 || i%3==0)continue; printf(\ s+=i; }

printf(\}

输出结果为: 1 5 7 11 13 37

1.编写一个函数,函数头格式为“void fun4(char *a , int b[])”,分别求出由字符指针a所指向的字符串中包含的每种十进制数字出现的次数,把统计结果保存在数组b的相应元素。 #include

void fun4(char* a,int b[]){ do{

if(*a>='0' && *a<='9')b[*a-48]++; }while(*a++); }

2. 编写一个函数,函数头格式为“double Mean(double a[M][N] , int m , int n)”,要求返回二维数组a[m][n]中所有元素的平均值,假定在计算过程是采用变量v存放平均值。 #include const int M=2,N=3;

double Mean(double a[M][N], int m,int n ){ double v=0;

for(int i=0;i

for(int j=0;j

3. 编写一个递归函数“int FF(int a[] , int n)”,求出数组a中所有元素n个元素之积并返回。 #include

int FF(int a[] , int n){ int mul=1;

if(n==1)mul*=a[0];

else mul=a[n-1]*FF(a,n-1); return mul; }

4. 编写一个主函数,利用while循环,求出并显示满足不等式1+1/2+1/3+??+1/n>5的最小n值。 #include void main() {

double sum=0; int n=1; while(true)

{

if(sum + 1/(double)n > 5)break; else

sum += 1/(double)n; n++; }

printf(\}

5. 编写一个主函数,求满足不等式22+42+??+n2<1000的最大n值,假定分别用i和s为取偶数值和累加值的变量,并限定使用do循环编程。 #include void main() {

int s=0,i=2; do {

s+=i*i;

if(s+(i+2)*(i+2)>=1000)break; else i+=2; }while(true);

printf(\}

6. 编写一个主函数,计算并输出n 的值,其中n值由键盘输入。 #include void main() {

int s=0,n;

printf(\请输入n的值:\ scanf(\

for(int i=1;i<=n;i++) s+=i*i; printf(\}

C语言程序设计形成性考核册参考答案作业三

一、 选择题

1. 在下面的(C)函数声明语句存在语法错误。

A.AA(int a,int b); B.AA(int ,int) C.AA(int a;int b) D.AA(int a,int)

2.在下面的(C)不能作为函数的返回类型。

A.void B.int C.new D.long 3.下面正确的函数原型语句是(B)。

A.int Function(void a); B.void Function(int); C.int Function(a); D.void int(double a);

4.函数调用func(exp1,exp2),exp3*exp4-exp5)中所含实参的个数为(B)个。 A.1 B.2 C.4 D.5 5.下面的标识符中,(C)是文件级作用域。 A.函数形参 B.语句标号 C.外部静态类标识符 D.自动类标识符

6.下面的标识符中,(B)具有全局级作用域。 A.函数形参 B.全局变量 C.内部静态类标识符 D.自动变量符

7.假定p是一个指向float型数据的指针,则p+1所指数据的地址比p所指数据的地址大( C )字节。

A.1 B.2 C.4 D.8

8.假定a为一个字符数组名,则a[8]的地址比该数组的首地址大( B )个字节。

A.4 B.8 C.16 D.32 9.假定a为一个数组名,则下面的( B )表示有错误。

A.a[i] B.*a++ C.*a D.*(a+1)

10.用calloc函数创建具有10个整型元素的一维数组的正确语句是( C )。 A.int *p=calloc(10,2); B.int *p=callo(10; C.int *p=calloc(10,4); D.int *p=malloc(10); 11.假定变量m定义为“int m=7;”,则定义p的正确语句为( B )。

A.int p=&m; B.int *p=&m; C.int &p=*m; D.int *p=m;

12.假定k是一个double类型的变量,则定义指向k的变量p的正确语句为( B )。

A.double p=&k; B.double *p=&k; C.double &p=*k; D.char *p=”Thank you!”;

13.假定一条定义语句为“int a[10],x,*pa=a;”,若要把数组a中下标为3的元素赋值给x,则不正确的语句为( D )。

A.x=pa[3]; B.x=*(a+3); C.a=a[3]; D.x=*pa+3;

14.假定有定义“int b[10];int *pb;”,则不正确的赋值语句为( C )。 A.pb=b; B.pb=&b[0]; C.pb=b+2; D.pb=b[5]; 15.假定指针变量p定义为“int *p=new int(100);”,要释放p所指向的动态

内存,应使用语句( D )。

A.delete[p]; B.delete *p; C.delete &p; D.delete []p;

16.假定指针变量p定义为“int *p=calloc(30,sizeof(int));”,要释放p所指向的动态内存,应使用语句( D )。

A.delete[p]; B.deldete(p); C.free[]p; D.free(p);

二、填空题

1.在C语言中,一个函数由函数头和___函数体_______组成。

2.在函数外定义的变量称为全局变量,若没有被初始化则系统隐含对它所赋的初值为___0______。

3.如果一个函数只允许同一程序文件中的函数调用,则应在访函数定义前加上的C保留字为为___static______。

4.如果一个函数直接或间接地调用自身,这样的调用被称为__递归_____调用。 5.调用系统函数时,要先使用#include命令包含该函数的原型语句所在__头___文件。

6.函数形参的作用域是该函数的__内部___。 7.假定p所指对象的值为25,p+1所指对象的值为46,则*p++的值为__25______。 8.假定p所指对象的值为25,p+1所指对象的值为46,则*++p的值为__46______。 9.假定p所指对象的值为25,p+1所指对象的值为46,则执行“*(p++);”语句后,p所指对象的值为__46______。

10.假定a是一个指针数组,则a+1所指对象的地址比a地址大__4___字节。 11.若要把一个整型指针p转换为字符指针,则采用的强制转换表达式为___(char*)p______。 12.假定一个数据对象为int*类型,则指向该对象的指针类型为__int**______。 13.假定p是一个指向整数对象的指针,则用___&p___表示指针变量p的地址。 14.若p指向x,则___*p___与x的等价的。 15.NULL是一个符号常量,通常作为空指针值,它值为__ ’\\0’ (ASCII码0)___。

三、写出下列每个程序运行后的输出结果 1. #include void SB(char ch){

switch (ch){

case 'A':case 'a':

printf(\ case 'B':case 'b':

printf(\ case 'C':case 'c':

printf(\ default:printf(\ } }

void main(){

char a1='b',a2='C',a3='f';

SB(a1);SB(a2); SB(a3);SB('A'); printf(\}

输出结果为: GGPPBBWW

2. #include #include

double SD(int a,int b,char op){ double x; switch(op){

case '+':x=a+b;break; case '-':x=a-b;break; case '*':x=a*b;break;

case '/':if(b)x=(double)a/b; else exit(1); break;

default:{(\运算符错!\\n\ }

return x; }

void main(){

int x=20,y=8;

printf(\ printf(\ printf(\}

输出结果为:

12.00 160.00 2.50

3. #include void WF(int x,int y){

x=x+y; y=x+y;

printf(\}

void main(){

int x=18,y=23;

printf(\ WF(x,y); x=2*x;

printf(\}

输出结果为: main:x,y=18,23 subs:x,y=41,64 main:x,y=36,23

4. #include #include void fun(char ss[]); void main(){

char s[15]=\ fun(s);

printf(\}

void fun(char ss[]){

int i,n=strlen(ss); for(i=0;i

char c=ss[i]; ss[i]=ss[n-1-i]; ss[n-1-i]=c; } }

输出结果为: 432198765

5. #include

void InsertSort(int a[],int n) {

int i,j,x;

for(i=1;i

x=a[i];

for(j=i-1;j>=0;j--)//为x顺序向前寻找合适的插入位置

if(x>a[j])a[j+1]=a[j]; else break; a[j+1]=x; } }

void main() {

int i;

int a[6]={20,15,32,47,36,28}; InsertSort(a,6);

for(i=0;i<6;i++)printf(\ printf(\}

输出结果为:

47 36 32 28 20 15

6. #include

void main(){

int a[8]={3,5,7,9,11,13,15,17}; int i,*p=a;

for(i=0;i<8;i++){; printf(\

if( (i+1)%4==0 )printf(\ } }

输出结果为:

3 5 7 9 11 13 15 17

7. #include int LA(int *a,int n){ int i,s=0;

for(i=0;i

s+=a[i]; return s; }

void main(){

int a[]={5,10,15,20,25,30}; int b=LA(a,4); int c=LA(a+2,3);

printf(\}

输出结果为: 50 60

8. #include int LB(int *a,int n){ int i,s=1;

for(i=0;i

void main(){

int a[]={1,2,3,4,2,4,5,2}; int b=LB(a,4)+LB(&a[3],4); printf(\}

输出结果为: b=184

四、写出下列每个函数的功能

1. #include

int WB(int a[],int n,int x){

for(int i=0;i

if(a[i]==x)return 1; return 0; }

函数功能为:

根据整型数组元素中是否能找到整数x,返回1或0

2. #include

int WC(int a[],int n,int k){

int c=0;for(int i=0;i=k)c++; return c; }

函数功能为:

返回数组中前n个其值大于等于k的元素之和

3. #include #include #include const int N=10;

int ff(int x,int y){ int z;

printf(\ scanf(\

if(x+y==z)return 1;else return 0; }

void main() {

int i,a,b,c=0;

srand(time(0)); //初始化随机数系列 for(i=0;i

a=rand() +1; //rand90函数产生0-32767之间的一个随机数

b=rand() +1; c+=ff(a,b); }

printf(\得分:%d\\n\}

函数功能为:

函数ff让两个数相加,要求输入其和,判断结果是否正确。在主函数中用随机函数产生两个20以内的随机整数,通过10次调用这个函数,算对一次得10分,计算所得分

4. int fun6(int m,int n,int b=2) {

if(m

else if(m%b==0 && n%b==0)return b*fun6(m/b,n/b,b); else return fun6(m,n,++b); }

函数功能为:

此函数带有一个默认参数,若使用默认值,则通过递归调用,返回前2参数的最小公倍数;

不使用默认值时,若最后一个参数不小于前2个参数,则返回前2参数之乘积; 否则,通过递归调用,返回前2参数最小公倍数的n倍数。

5. #include #include void LI(int n){

int * a=(int *) malloc(n*sizeof(int)); int i;

for(i=0;i

for(i=n-1;i>=0;i--)printf(\ printf(\ free(a); }

函数功能为:

将从键盘输入的n个整数逆序输出

6. #include

int LK(double a[],int n){

double s=0;int i,m=0; for(i=0;i

for(i=0;i=s)m++; return m; }

函数功能为:

求不小于数组元素之平均值的各元素之和(前n个)

应加入此4字,否则D亦对

必须强制类型转换!否则提示cannot convert from 'void *' to 'int *'

C语言程序设计形成性考核册参考答案作业四

一、 选择题

1. 假定有“struct BOOK{char title[40];float price;};struct BOOK *book;”,则不正确的语句为(A)。

A.struct BOOK *x=malloc(book); B.struct BOOK x={“C++ Programming”,27.0}; C.struct BOOK

*x=malloc(sizeof(BOOK)); D.struct BOOK **x=&book; 2. 假定有“struct BOOK{char title[40];float price;} book;”,则正确的语句为(B)。

A.struct BOOK x=&book; B.struct BOOK *x=&book; C.struct BOOK x=calloc(BOOK); D.struct BOOK *x=BOOK; 3.表示文件结束的符号常量为(C)。

A.eof B.Eof C.EOF D.feof 4.C语言中系统函数fopen()是(D)一个数据文件的函数。

A.读取 B.写入 C.关闭 D.打开 5.从一个数据文件中读入以换行符结束的一行字符串的函数为(B)。 A.gets() B.fgets() C.getc() D.fgetc() 6.向一个二进制文件写入信息的函数fwrite()带有(D)参数。

A.1 B.2 C.3 D.4

二、填空题

1.假定一个结构类型的定义为“struct A{int a,b;A*c;};”,则该类型的大小为___12_______字节。

2.假定一个结构类型的定义为“struct B{int a[5],char *b;};”,则该类型的大小为___24_______字节。

3.假定一个结构类型的定义为“struct D{int a;union{int b;double c;};struct D* d[2];};”,则该类型的大小为___20 _______字节。 4.假定要动态分配一个类型为struct Worker的具有n个元素的数组,并由r指向这个动态数组,则使用语句的表达式为struct Worker* r=__(Worker*)malloc(n*sizeof(Worker));_____。

5.假定要访问一个结构x中的由a指针成员所指向的对象,则表示方法为__x.(*a)___。

6.假定要访问一个结构指针p所指向对象中的b指针成员所指的对象,则表示方法为_____ *(p->b)___

7.与结构成员访问表达式(*fp).score等价的表达式是__fp->score______。

三、写出下列每个程序运行后的输出结果 1. #include struct Worker{

char name[15]; //姓名 int age; //年龄 float pay; //工资 };

void main(){

struct Worker x={\ struct Worker y,*p;

y=x;p=&x;

printf(\ printf(\}

输出结果为: wanghua 52 23.50 wanghua 52 23.50

2. #include #include struct Worker{

char name[15]; //姓名 int age; //年龄 float pay; //工资 };

void main(){

struct Worker x; char *t=\ int d=38;float f=493; strcpy(x.name,t); x.age=d;x.pay=f; x.age++;x.pay*=2;

printf(\}

输出结果为: louting 39 986.00

3. #include #include struct Worker{

char name[15]; //姓名 int age; //年龄 float pay; //工资 };

int Less(struct Worker r1,struct Worker r2){ if(r1.age

void main(){

struct Worker

a[4]={{\ struct Worker x=a[0]; int i;

for(i=1;i<4;i++)

if(Less(x,a[i]))x=a[i];

printf(\}

输出结果为: def 58 638.00

四、写出下列每个函数的功能 1.

void QA(struct Worker a[],int n){ int i;

for(i=0;i

scanf(\ay); }

假定结构struct Worker的定义如下: #include #include #include struct Worker{

char name[15]; //姓名 int age; //年龄 float pay; //工资 };

函数功能为:

输入struct Worker 类型的对象a[n]的各个元素的值

2. struct StrNode *QB(int n){

StrNode * f,*p; if(n==0)return NULL;

f=(StrNode*) malloc(sizeof(struct StrNode)); scanf(\ p=f; while(--n){

p=p->next=(StrNode*)malloc(sizeof(struct StrNode));

scanf(\ }

p->next=NULL; return f; }

假定结构struct StrNode的定义如下: struct StrNode{

char name[5];

struct StrNode *next; };

函数功能为:

建立一个具有n个结点,每个结点的类型是StrNode的链表

3. struct IntNode* FindMax(struct IntNode *f) {

struct IntNode *p=f; if(!f)return NULL; f=f->next; while(f){

if(f->data < p->data)p=f; f=f->next; }

return p; }

假定结构struct StrNode的定义如下: struct IntNode{ int data;

struct IntNode * next; };

函数功能为:

在一个具有n个结点,每个结点的类型是IntNode的链表中寻找data值最大的结点

4. int Count(struct IntNode *f) {

int c=0;while(f){ c++; f=f->next; }

return c; }

假定结构struct StrNode的定义如下: struct IntNode{ int data;

struct IntNode * next; };

函数功能为:

计算一个具有n个结点,每个结点的类型是IntNode的链表的结点数

5. struct IntNode* Input(int n) {

struct IntNode *f,*p;

f=(IntNode*)malloc(sizeof(struct IntNode));

if(n==0)return NULL; f->next=NULL;

printf(\从键盘输入 %d 个整数:\ while(n--){

scanf(\ p=f;

f=(IntNode*)malloc(sizeof(struct IntNode)); f->next=p; }

return f->next; }

假定结构struct StrNode的定义如下: struct IntNode{ int data;

struct IntNode * next; };

函数功能为:

在类型为IntNode的链表后输入n个结点的数据

6. #include #include #include

void JA(char* fname) {

FILE* fout=fopen(fname,\ char a[20]; printf(\ while(1){

scanf(\

if(strcmp(a,\ fputs(a,fout); fputc('\\n',fout); }

fclose(fout); }

void main() {

char *p=\ JA(p); }

函数功能为:

在已经存在的d:\\xxk文件夹下(如不存在此文件夹程序运行会出错)打开xuxk1.txt文件,并向其中输入一系列长度小于20的字符串,直到输入字符串end结束。

理论值。用sizeof(D)得到的结果是 24,说明编译系统采用的结构成员对齐方式是8个字节

原错为1,数组是第一个元素下标应为0!

VC++6.0不能将void *赋值给其它类型,必须强制转换

本文来源:https://www.bwwdw.com/article/pweg.html

Top