阅读以下说明,回答问题1至问题3,将答案填入答题纸对应栏内。【说明】在某嵌入式处理器上,编写以下两
阅读以下说明,回答问题1至问题3,将答案填入答题纸对应栏内。
【说明】
在某嵌入式处理器上,编写以下两段秸序(编译选项中,存储采用4字节对齐方式)。
程序段1:
struct studentl {
char name [10] ;
long sno;
char sex;
float score [4] ;
*pl, al, bl;
程序段2:
union student2 {
char name [10] ;
long sno;
char sex,
float score [4] ;
*p2, a2, b2;
汉诺塔问题说明:有n个盘子在A处,盘子从小到大,最上面的盘予最小,程序要
把这n个盘子从A处搬到C处,可以在E处暂存,但任何时候都不能出现大的盘子压
在小的盘子上面的情况。
下列是一段求解汉诺塔问题的C语言程序。
include <stdio . h>
void move (int n, char a, char c)
{
static int Step=l;
printf ("Step %2d: Disk %d %c..--> %c\n", Step, n, a, c) ;
Step++;
}
void Hanoi (int n, char a, char b, cnar c)
{
if (n>l)
{
Hanoi (n-l, a, c, b) ;
move (n, a. c) ;
Hanoi (n-l, b, a, c) ;
}
else move (n,a,c);
}
void main()
{
Hanoi(3, ’A’, 、B’, 、C ’);
}
【问题1】(3分)
C语言函数的一般格式为:
<函数类型> <函数名> (<参数列表>)
{
<函数体>;
}
简答下述问题,将答案填写在答题纸中对应栏目。
(l)<函数类型>的含义是什么?
(2)<参数列表>的含义是什么?
(3)C语言函数之间的参数如何传递?
【问题2] (6分)
回答问题,将答案填写在答题纸中对应栏目。
(1)sizeof(struct studentl)结果是多少
(2) sizeof(union student2)结果是多少
(3)变量a2在程序段2中定义,写出执亍以下语句后的输出结果。
strcpy (a2. name,¨zhangwei¨);
a2.sex=’f’;
printf ("%s¨, a2 .name);
【问题3](6分)
仔细阅读求解汉诺塔问题的C语言程序,完成其中(1)~(4)空白填空,将答案
填入答题纸的对应栏内。
运行结果为:
Step1:Disk l A---->C
Step 2: (l)
Step 3: Disk I C---->B
Step4: (2)
Step 5: (3)
Step 6: Disk 2 B---->C
Step 7: (4)
本题考查C语言应用知识。
【问题l】
C语言函数的一般格式为:
<函数类型><函数名>(<参数列表>:
(
<函数体>;
)
其中<函数类型>为函数返回值的类型,无返回值时应写void;<参数列表>为函数
的接口参数,可以为空,即表示没有参数,但函数名后面的0不能省略。
C语言函数之间的参数传递是传值,是通过栈来传递的。调用时所有参数在栈中新
开辟相应类型的单元并将实参值填入,函数中对参数的任何操作都是对栈中单元的操作,
调用结束,栈中开辟的相应单元都会释放,并不影响实参变量的值。
【问题2】
studentl是一个结构体,sizeof(structstudentl)结果为所有元素字节数之和,因此
sizeof(structstudentl)结果为:10+4+1-16=31字节。
student2是联合体(或共用体),sizeo(unionstudent2)结果为其中最长一个元素的
字节数。因此sizeof(unionstudent2)结果为:16字节。
变量a2在程序段2中定义,执行以下语句:
Strcpy(a2.name,”zhangwei”)
a2.sex=f;
Printf(“%s,a2.name);
结果为:“fhangwei”
【问题3]
汉诺塔问题是指有n个盘子在A处,盘子从大到小,最上面的盘子最小,现在要把
这n个盘子从A出搬到C处,可以在B处暂存,但任何时候不能出现大的盘子压在小
的盘子上面的情况。算法如下:
(1)若n=l,则可以将盘子直接从A处搬到C处;
(2)假设n-l时,指导如何解;
(3)则n时,根据(2)的假设,可以先把前n-1个盘子从A处通过C处搬到B处,
就可以把第n个盘子直接从A处搬到C处,再把前n-l个盘子从B处通过A处搬到C
处,则完成了全部盘子搬动。
因此,运行结果为:
Step1:DisklA---->C
Step2:Disk2A---->B
Step3:DisklC----->B
Step4:Disk3A----->C
Step5:DisklB----->A
Step6:Disk2B----->C
Step7:DisklA----->C
参考答案
【问题1]
(l)<函数类型>的含义是:函数返回值的类型,无返回值时应写为void;
(2)<参数列表>的含义是:函数的接口参数,可以为空,即表示没有参数,但函
数名后面的()不能省略。
(3)C语言函数之间的参数传递是传值,是通过栈来传递的。
【问题2]
(1)sizeof(structstudentl)结果为:31
(2)sizeof(unionstudent2)结果为:16
(3)执行语句后的结果为:“fhangwei”
【问题3]
(1)Disk2A->B
(2)Disk3A->C
(3)DisklB->A
(4)DisklA->C
某实验小组在探究物体的加速度a与物体所受合外力F、物体质量M间的关系时,采用如图甲所示的实验装置, 物理 2020-05-16 …
如图表示某高等动物激素的分泌及作用机制,结合所学知识及图中相关信息回答以下问题:(1)图中甲、乙、 其他 2020-06-10 …
如图表示血液流经泌尿系统的某些结构时,血浆中某些物质含量的变化,根据图示回答以下问题.①该图表示血 语文 2020-06-13 …
某氯化铁和誡化亚铁样品混合物,现要测定其中铁元素的质垃分数’实验按以下步骤进打请根据下面流程,回答 化学 2020-06-22 …
某校化学研究性学习小组在学习了乙醇、乙醛的性质后,进行了以下实验探究.试回答以下问题:(1)按上图 化学 2020-07-29 …
如图所示是淮安某餐厅出现的一款送餐机器人,它是一种新型的用电器,可以把做好的食物按照指定的轨迹送到 物理 2020-08-01 …
为啥如果用手堵住连通器的一个开口后,连通器中水面不会相平?(以U型连通器为例,回答以下两个问题)①只 物理 2020-11-28 …
(10分)下列图(I)是部分常用化学仪器或装置,图(Ⅱ)某微型实验的装置图。对比图(I)图(Ⅱ)回答 化学 2020-12-12 …
化学是一门以实验为基础的学科,通过一年的学习,相信你的实验能力一定有了很大提高,请你一同参与回答以下 化学 2020-12-18 …
(8分)空间探测器从某一星球表面竖直升空,已知探测器质量为500kg(设为恒量),发动机推力为恒力, 物理 2020-12-28 …