形考任务4
试卷总分:100 得分:100
一、选择题(共30分,每小题2分)
1.假定有“struct BOOK{char title[40]; float price;}; struct BOOK book;”,则不正确的语句为( )。
A.struct BOOK *x=malloc(book);
B.struct BOOK x={“C++ Programming”,27.0};
C.struct BOOK *x=malloc(sizeof(struct BOOK));
D.struct BOOK *x=&book;
2.假定有“struct BOOK{char title[40]; float price;} book;”,则正确的语句为( )。
A.struct BOOK x= &book;
B.struct BOOK *x=&book;
C.struct BOOK x=calloc(BOOK);
D.struct BOOK *x=BOOK;
3.在结构类型的定义中,不同数据成员的定义项之间采用的分隔符是( )。
A.句点
B.冒号
C.分号
D.逗号
4.假定一个结构类型的定义为 “struct A{int a,b; double c;};”,则该类型的长度为( )。
A.8
B.10
C.12
D.16
5.假定一个结构类型的定义为 “struct D{int a; D* next;};”,则该类型的长度为( )。
A.4
B.8
C.12
D.16
6.假定要访问一个结构指针变量x中的数据成员a,则表示方法为( )。
A.a
B.x->a
C.x(a)
D.x{a}
7.与结构成员访问表达式x.name等价的表达式为( )。
A.x->name
B.&x->name
C.(&x)->name
D.(*x)->name
8.假定一个链表中结点的结构类型为“struct AA{int data, struct AA *next;};”,则next数据成员的类型为( )。
A.struct AA
B.struct AA*
C.AA
D.int
9.假定一个链表的表头指针为f,结点中包含有data和next域,则向该链表的表头插入一个地址为p的结点时,应执行的操作为( )。
A.p->next=f
B.p->next=f和f=p
C.f=p->next
D.f->next=p和f=p
10.标准输入设备键盘的文件流标识符是( )。
A.stdin
B.stdout
C.stderr
D.stdio
11.表示文件结束符的符号常量为( )。
A.eof
B.Eof
C.EOF
D.feof
12.C语言中打开一个数据文件的系统函数为( )。
A.fgetc()
B.fputc()
C.fclose()
D.fopen()
13.从一个数据文件中读入以换行符结束的一行字符串的系统函数为( )。
A.gets()
B.fgets()
C.getc()
D.fgetc()
14.向一个二进制文件中写入信息的函数fwrite()带有的参数个数为( )。
A.1
B.2
C.3
D.4
15.在C语言中,为只写操作打开一个文本文件的方式为( )。
A.”a”
B.”r+”
C.”r”
D.”w”
国开电大答案请进:opzy.net或请联系微信:1095258436
二、判断题(共40分,每小题2分。叙述正确则回答“是”,否则回答“否”)
16.在结构类型的定义中,其中的数据成员可以是本身类型的直接对象。
17.在结构类型的定义中,允许出现结构类型不完整的超前定义。
18.定义结构类型的变量时,不能够同时进行初始化。
19.使用一个结构类型时,必须一起使用关键字struct和类型标识符。
20.假定一个结构类型的定义为 “struct A{int a,b; A* c;};”,则该类型的长度为12。
21.假定一个结构类型的定义为 “struct B{int a[5]; char* b;};”,则该类型的长度为20。
22.执行calloc(n,8)函数调用时,将动态分配得到8*n个字节的存储空间。
23.执行malloc(sizeof(struct BB))函数调用时,得到的动态存储空间能够保存具有struct BB结构类型的一个对象。
24.假定要访问一个结构对象x中的由a指针成员所指向的对象,则表示方法为x.a。
25.假定要访问一个结构指针p所指对象中的b指针成员所指的对象,则表示方法为p->b。
26.与结构成员访问表达式(*fp).score等价的表达式是fp->score。
27.在C语言中,对二进制文件的所有不同打开方式共有6种。
28.C语言中的标准输入和输出设备文件都属于字符文件。
29.在一个磁盘数据文件的文件名中,文件主名和扩展名都是必须的,不可省略。
30.在数据文件打开方式字符串中,字符r、w和a具有确定的含义,分别代表读、写和追加方式。
31.一个磁盘数据文件的文件名由文件主名和扩展名所组成,其中间用圆点分开。
32.C语言系统中提供一个用来描述文件属性的类型标识符为FILE。
33.每次只能向文本文件中写入一个字符,不能一次写入一个字符串。
34.对二进制文件进行读和写操作将使用相同的系统函数。
35.在C语言中,系统函数fseek()用来移动数据文件中的文件位置指针。
三、写出下列每个程序运行后的输出结果(共15分,每小题5分)
36.#include<stdio.h>
struct Worker {
char name[15]; //姓名
int age; //年龄
float pay; //工资
};
void main() {
struct Worker x={“wanghua”,52,4300};
struct Worker y, *p;
y=x; p=&x;
printf(“%s %d %6.2f\n”,x.name,y.age,p->pay);
}
37.#include<stdio.h>
#include<string.h>
struct Worker {
char name[15]; //姓名
int age; //年龄
float pay; //工资
};
void main() {
struct Worker x;
char *t=”liouting”;
int d=38; float f=3493;
strcpy(x.name,t);
x.age=d; x.pay=f;
printf(“%s %d %6.0f\n”,x.name,x.age,x.pay);
}
38.#include<stdio.h>
struct Worker {char name[15]; int age; float pay;};
int Less(struct Worker r1, struct Worker r2) {
if(r1.age<r2.age) return 1; else return 0;
}
void main() {
struct Worker a[4]={{“abc”,25,2420},{“def”,58,4638},
{“ghi”,49,4260},{“jkl”,36,3750}};
struct Worker x=a[0];
int i;
for(i=1; i<4; i++)
if(Less(x,a[i])) x=a[i];
printf(“%s %d %6.0f\n”,x.name,x.age,x.pay);
}
四、写出下列每个函数的功能(共15分,每小题5分)
39.void QA(struct Worker a[], int n) {
int i;
for(i=1; i<n; i++)
scanf(“%s %d %f”,&a[i].name,&a[i].age,&a[i].pay);
}
假定结构类型struct Worker 的定义如下:
struct Worker { char name[15]; int age; float pay;};
40.int Count(struct IntNode *f)
{ //f为指向一个单链表的表头指针
int c=0;
while(f) {
c++;
f=f->next;
}
return c;
}
假定struct IntNode的类型定义为:
struct IntNode {int data; IntNode* next;};
41.void xw1(char* fname) {
FILE* fout=fopen(fname,”w”);
char a[20];
printf(“每个字符串长度小于20,字符串end作为结束标志\n”);
while(1) {
scanf(“%s”,a);
if(strcmp(a,”end”)==0) break;
fputs(a,fout);
fputc(‘\n’,fout);
}
fclose(fout);
}
奥鹏国开作业答案请进opzy.net或添加微信:1095258436