- 50
- 0
- 约2.34千字
- 约 4页
- 2017-12-15 发布于河南
- 举报
上海交大十月份数据结构上机实验考试题 2012-11-17
模 拟 题
一、有一只猫抓了n (n1)个老鼠后向老鼠宣布:老鼠按自然数进行编号(1~n),并按自然数顺序排队,以后先后次序不准变;于是猫每天吃掉编号为奇数的老鼠,剩下的老鼠再按原次序进行自然数编号,直至某一天只剩下一只小老鼠;而该小老鼠是猫从第一天起就想吃掉的那只,请问这只小老鼠的最初编号是几?
用链结构实现,链的每个节点所包含的“数据域”信息是老鼠的最初编号(从1开始编号),另一个信息是链的下一节点地址。
建立一条有n个节点的链:先创建一个空链,然后向链尾插入n 个节点。
开始删除奇数节点:从链首开始删除“奇”节点,直至链尾;判断链是否只剩下一个节点?不是则循环执行上一步,是则结束循环。
输出结果。
程序编写完成后,请以f1.c或f1.cpp作为文件名存放到F盘上。
答案:
#include iostream.h
#include assert.h
struct mouse //链“节点”类声明
{
int n;
mouse *nextptr;
};
int cat_mouse(int num) //函数定义
{
mouse *headptr=0,*tailptr=0,*frontptr,*p;
int i;
//先把1个老鼠加入链作为链首节点
headptr=tailptr=new mouse;
assert(headptr!=NULL); //动态内存分配异常处理
headptr-n=1; //老鼠的编号
headptr-nextptr=NULL;
//在链尾再添加n-1个老鼠
for(i=2;i=num;++i)
{p=new mouse;
assert(p!=NULL);
p-n=i;
coutp-n ;
tailptr-nextptr=p;
tailptr=p;
}
tailptr-nextptr=NULL; //设置链尾节点的“下一节点地址”为空
//开始删除老鼠
while(headptr!=tailptr) //每循环一次,删除链上的奇节点,直至只剩下1个节点
{ p=headptr-nextptr; //链的首节点总是先被删除
delete headptr; //析构首节点
headptr=frontptr=p; //本次循环的第2个节点成为链的首节点
i=2; //从第2个节点开始循环:删除链的奇节点
while(p!=NULL) //从2开始循环至链尾节点
{if((i%2)==1) //是奇节点
{if (p-nextptr==NULL) //如果该奇节点是最后一个节点
{frontptr-nextptr=NULL; //前一节点成为链的尾节点
tailptr=frontptr;
delete p;
p=NULL; //因本循环的判断条件是p!=NULL,到链尾,所以置为0
}
else //是奇节点但不是尾节点,删除
{frontptr-nextptr=p-nextptr; //从链上删除该奇节点
delete p;
p=frontptr-nextptr; //下一节点的地址已保存在frontPtr的 nextPtr中
++i;
} //frontPtr成为被删节点的下一节点的上一节点,故值不变
}
else //不是奇节点,不删除
{frontptr=p;
p=p-nextptr;
++i;
}
}
}
return headptr-n; //返回最后一个节点的编号
}
void main()
您可能关注的文档
最近下载
- 【高考真题】2022年新高考物理真题试卷——湖南卷(含答案).pdf VIP
- 毕业设计论文-江苏工程职业技术学院.doc VIP
- 新人教版八年级物理下册第七章练习题.docx VIP
- 2022电网企业文化、电力与能源战略题库.pptx VIP
- 索尼A7RM3A使用说明书+入门帮助指南【完整电子版】.pdf VIP
- 【武汉市生鲜农产品的冷链物流发展现状、问题及对策探究16000字(论文)】 .pdf
- 2026版教师职称-山西-山西教师职称(基础知识、综合素质、高中信息技术)历年参考题库含答案解析5套.docx VIP
- 2020-2021学年江苏省淮安市淮阴中学八年级(上)期末物理试卷含解析.doc VIP
- 变压器油中溶解气体在线监测装置.docx VIP
- 2026年春新版二年级道德与法治下册教学计划(含教学进度表).pdf VIP
原创力文档

文档评论(0)