C语言程序设计姚琳扫描版,C语言程序设计 第2版 习题答案 作者 姚琳 教材课后题答案 第7章.doc...

习题7

一 单选题

1.设有如下定义,则表达式sizeof(y)的值是【 】。

struct data

{long *ln;

char c;

struct data *last,*next;

}y;

A.7B.9C.13D.17

【答案】C

【解析】指针变量在内存中占用4个字节,所以sizeof(y)的值是4+1+4+4=13

2.设有以下程序段,则表达式的值不为100的是【 】。

struct st

{int a;int *b;};

void main()

{int m1[]={10,100},m2[]={100,200};

struct st *p,x[]={99,m1,100,m2};

p=x;

...

}

A.*(++p->b)B.(++p)->aC.++p->aD.(++p)->b

【答案】D

【解析】根据题意,p指向x数组,x[0]的b成员指向m1数组,x[1]的b成员指向m2数组,如图7-1所示。选项A中p->b指向m1[0],通过“++”运算p->b指向m1[1],所以选项A的表达式的值为100。选项B中++p使p指向x[1],x[1]的a成员的值是100。选项C中p指向x[0],x[0]的a成员做“++”运算,结果为100。选项D中++p使p指向x[1],x[1]的b成员的值是指针,所以选择选项D。

图7-1

3.设有以下定义,且如图7-2所示,指针head和p指向链表的第一个结点,指针q指向新的结点,则不能把新结点插入在第一个结点之前的语句是【 】。

图 7-2

struct node

{int a;

struct node *next;

}*head,*p,*q;

A.head=q,q->next=p;B.head=q,q->next=head;

C.q->next=head,head=q;D.head=q,head->next=p;

【答案】B

4.设有如下结构体说明和变量定义,且如图7-3所示,指针p指向变量one,指针q指向变量two,则不能将结点two接到结点one之后的语句是【 】。

图 7- 3

struct node

{int n;

struct node *next;

}one,two,*p=&one,*q=&two;

A.p.next=&two;B.(*p).next=q;

C.one.next=q;D.p->next=&two;

【答案】A

【解析】p是指向结构体的指针,因此选项D是规范的引用方式。

5.设有以下定义,且如图7-4所示建立了链表,指针p、q分别指向相邻的两个结点,下列语句中【 】不能将p所指向的结点删除。

图 7- 4

struct node

{int a;

struct node *link;

}*head,*p,*q;

A.q->link=p->link;B.p=p->link,q->link=p;

C.(*p).link=(*q).link;D.p=(*p).link,(*q).link=p;

【答案】C

6.以下选项中,能正确地将x定义为结构体变量的是【 】。

A.structB.typedef struct st

{int i; {int i;

float j;float j;

}x;}x;

C.struct stD.typedef st

{int i; {int i;

float j; float j;

} }

st x;st x;

【答案】A

【解析】选项C语法错误。

7.若有如下定义,则sizeof(struct no)的值是【 】。

struct no

{int n1;

float n2;

union nu

{char u1[6];

double u2;

}n3;

};

A.12B.14C.16D.10

【答案】C

【解析】4+4+max{6,8}=16。

8.设有如下定义,则下列叙述中正确的是【 】。

typedef struct

{int s1;

float s2;

char s3[80];

}STU;

A.STU是结构体变量名B.typedef struct是结构体类型名

C.STU是结构体类型名D.struct是结构体类型名

【答案】C

9.设有如下定义,则引用共用体中h成员的正确形式为【 】。

union un

{int h;char c[10];};

struct st

{int a[2];

union un h;

}s={{1,2},3},*p=&s;

A.p.un.hB.(*p).h.hC

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值