数据结构程序设计题目共29题

上传人:博****1 文档编号:490324833 上传时间:2022-09-02 格式:DOC 页数:14 大小:125KB
返回 下载 相关 举报
数据结构程序设计题目共29题_第1页
第1页 / 共14页
数据结构程序设计题目共29题_第2页
第2页 / 共14页
数据结构程序设计题目共29题_第3页
第3页 / 共14页
数据结构程序设计题目共29题_第4页
第4页 / 共14页
数据结构程序设计题目共29题_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《数据结构程序设计题目共29题》由会员分享,可在线阅读,更多相关《数据结构程序设计题目共29题(14页珍藏版)》请在金锄头文库上搜索。

1、题目 1:设计一元多项式简单计算 错误 !未定义书签。题目 2:链表应用 1 错. 误 !未定义书签。题目 3:链表应用 2 错误!未定义书签。题目 4:?通讯录 错误 ! 未定义书签。题目 5:停车场管理系统 . 错误!未定义书签。题目 6:约瑟夫环 . 错误!未定义书签。题目 7:运动会分数统计 . 错误!未定义书签。题目 8:文学研究助手问题 错误 !未定义书签。题目 9:银行业务模拟与离散事件模拟 错误 !未定义书签。题目 10:学生信息管理系统任务(用顺序表 / 链表) . 错误!未定义书签。 题目 11:文章编辑功能 错误 !未定义书签。题目 12:实验室管理 错误 !未定义书签。

2、题目 13:二叉树的基本操作(建立、求二叉树树深度、遍历). 错误 !未定义书签。题目 14:纸牌游戏任务 错误 !未定义书签。题目 15:算术表达式求值 . 错误 !未定义书签。题目 16:内部排序算法比较 错误 !未定义书签。题目 17:哈夫曼树的构造和哈夫曼编码 / 译码 错误 !未定义书签。题目 18:构造可以使 n 个城市连接的最小生成树 错误!未定义书签。题目 19:交通咨询系统中的最短路径 错误 !未定义书签。题目 20:集合的交、并、差运算 . 错误!未定义书签。题目 21:长整数四则运算 . 错误 !未定义书签。题目 22:机订票系统 错误 !未定义书签。题目 23:图书管理

3、系统 错误 !未定义书签。题目 24:哈希表应用 错误 !未定义书签。题目 25:模拟旅馆管理系统的一个功能床位的分配与回收. 错误 !未定义书签。题目 26:地图着色问题 错误 !未定义书签。题目 27:俄罗斯套娃问题 . 错误 !未定义书签。题目 28:扫雷 错误 !未定义书签。题目29:用C语言设计一个日历系统 错误!未定义书签。题目 1:设计一元多项式计算【任务要求】(1) 能够按照指数降序排列建立并输出多项式;(2) 能够完成两个多项式的相加、相减,并将结果输入; 实现提示:可选择带头结点的单向循环链表?或单链表存储多项式,头结点可存放多项式的参数,如项数等。要求: 在上交资料中请写

4、明:存储结构、 多项式相加的基本过程的算法 (可以使用程序流程 图) 、源程序、测试数据和结果、算法的时间复杂度、另外可以提出算法的改进方法;【测试数据】自行选择?题目 2:链表应用 1【任务要求】实现两个链表的合并 基本功能要求:(1) 建立两个链表 A和B,链表元素个数分别为m和n个。(2) 假设元素分别为(x1,x2,xm),和(y1,y2,yn)。把它们合并成一个线形表C,使 得:当 m=n时,C=x1,y1,x2,y2,xn,yn,xm当 nm时,C=y1,x1,y2,x2,ym,xm,yn输出线性表 C(3) 用直接插入排序法对C进行升序排序,生成链表D,并输出链表Do【测试数据】

5、1) A 表(30,41,15 ,12,56,80)B表(23,56,78,23,12,33,79,90,55)2) A 表(30,41,15 ,12,56,80,23,12 , 34)B 表( 23,56,78,23,12)题目 3:链表应用 2问题描述】已知非空线性链表第一个链结点的指针为 list ,写出下列各项操作的算法程序。( 1 )逆转该线性链表;( 2)删除线性链表中从左往右第一个数据为data 的链结点;( 3)删除从第 I 个链结点开始的连续 k 个结点。 【任务要求】设计一组输入数据并编写完整的程序。 调试程序并对相应的输出作出分析; 修改输入数 据,预期输出并验证输出的结

6、果。【提示】1)逆转一个链表是指在不增加新结点的前提下,依次改变链表中结点的连接方向。2)删除数据结点时, 首先判断链表是否为空, 若非空,先判断第一个结点是否满足条件,若 是则删除; 否则从第二个结点开始顺序查找, 直到找到为止, 然后删除;对任何不满足条件 的情况都报告相应提示信息。3)从第 I 个结点开始连续删除 k 个结点时,考虑以下两种情况:当 I=1 时,从第一个开始 删除即可;当11时,先找到前一个结点然后再连续删除K个结点。最后释放各个结点空间。【测试数据】自行设定题目 4:?通讯录【问题描述】该设计采用菜单作为应用程序的主要界面, 用控制语句来改变程序执行的顺序, 控制 语句

7、是实现结构化程序设计的基础。 该设计的任务是利用一个简单实用的菜单, 通过菜单单 项进行选择, 实现和完成通讯录管理中常用的几个不同的功能。 通讯者所包含信息请自行设 定【任务要求】 菜单内容: (0)通讯录链表的建立 (1 )通讯者结点的插入(2)通讯者结点的查询(3)通讯者结点的删除(4)通讯录链表的输出(5)退出管理系统 设计要求: 使用 05 来选择菜单项,其他输入则不起作用。功能函数设计5 个不同功能的算法实现编程题,目的是练习利用链表结构来解决实际应用问题的能力,进步理解和熟悉线形表的链式存储结构。【测试数据】 自行设定,注意边界等特殊情况。题目 6:约瑟夫环【问题描述】编号是1,

8、 2,n的n个人按照顺时针方向围坐一圈,每个人只有一个密码(正整 数)。一开始任选一个正整数作为报数上限值m,从第一个仍开始顺时针方向自 1开始顺序报数,报到m时停止报数。报 m的人出列,将他的密码作为新的 m值,从他在顺时针方向的 下一个人开始重新从 1 报数, 如此下去, 直到所有人全部出列为止。 设计一个程序来求出出 列顺序。【任务要求】 利用单向循环链表存储结构模拟此过程,按照出列的顺序输出各个人的编号。 输入数据:输入 m的初值,n,输入每个人的密码,建立单循环链表。 输出形式:建立一个输出函数,将正确的输出序列【测试数据】 m的初值为20,n=7,7个人的密码依次为 3,1,7,

9、2,4,7, 4。题目 7:运动会分数统计【问题描述】参加运动会有n个学校,学校编号为 1 n。比赛分成 m个男子项目,和 w个女子 项目。项目编号为男子 1m女子m+1m+w不同的项目取前五名或前三名积分;取前五名的积分分别为: 7、5、3、2、1 ,前三名的积分分别为: 5、3、2;哪些取前五名或前 三名由学生自己设定。( m=20,n=20)【任务要求】功能要求: 1). 可以输入各个项目的前三名或前五名的成绩;2) 能统计各学校总分,3) 可以按学校编号、学校总分、男女团体总分排序输出;4) . 可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名 的学校。规定:输

10、入数据形式和范围: 20 以内的整数(如果做得更好可以输入学校的名称,运 动项目的名称)输出形式:有中文提示,各学校分数为整型界面要求: 有合理的提示, 每个功能可以设立菜单, 根据提示,可以完成相关的功能要 求。存储结构: 学生自己根据系统功能要求自己设计, 但是要求运动会的相关数据要存储在 数据文件中。(数据文件的数据读写方法等相关内容在 c 语言程序设计的书上, 请自学解决) 请在最后的上交资料中指明你用到的存储结构;【测试数据】1、全部合法数据;2、整体非法数据;3、局部非法数据。 进行程序测试,以保证程序的稳定。测试数据及测试结果请在上交的资料中写明;题目 9:银行业务模拟与离散事件

11、模拟【问题描述】假设某银行有4个窗口对外接待客户,从早晨银行开门(开门9: 00am,关门5: 00pm)起不断有客户进入银行。 由于每个窗口在某个时刻只能接待一个客户, 因此在客户人数众多 时需要在每个窗口前顺次排队, 对于刚进入银行的客户 (建议: 客户进入时间使用随机函数 产生),如果某个窗口的业务员正空闲,则可上前办理业务;反之,若4 个窗口均有窗户所占,他便会排在人数最少的队伍后面。【任务要求】 编制一个程序以模拟银行的这种业务活动并计算一天中客户在银行逗留的平均时间。 建议有如下设置:客户到达时间随机产生,一天客户的人数设定为 100人。 银行业务员处理时间随机产生,平均处理时间1

12、0 分钟。将一天的数据(包括业务员和客户)以文件方式输出。【测试数据】 由随机数产生器生成题目 13:二叉树的基本操作(建立、求二叉树树深度、遍历)任务要求】 要求输入二树的各个结点,求二叉树的树深度,并能够输出指定遍历方式(层序、先序、中 序、后序)的遍历序列;分别建立;建立二叉树存储结构的的输入函数、求二叉树的树深度 的函数、遍历序列的函数层序遍历(用队列的方法实现) 中序遍历( 用递归和非递归的方法一起都实现) 先序遍历( 用递归和非递归的方法一起都实现) 后序遍历( 用递归和非递归的方法一起都实现)题目 14:纸牌游戏任务【问题描述】编号为 1-52 张牌,正面向上,从第 2张开始,以

13、 2为基数,是 2 的倍数的牌翻一次,直 到最后一张牌;然后,从第 3 张开始,以 3 为基数,是 3 的倍数的牌翻一次,直到最后一张 牌;然后从第 4张开始,以4为基数,是4的倍数的牌翻一次, 直到最后一张牌;. 再依次 5的倍数的牌翻一次, 6的, 7的 直到 以 52 为基数的 翻过,输出:这时正面向上 的牌有哪些?【任务要求】采用合适的数据结构输出最后正面向上的牌,并将以252奇数翻牌的过程显示出来题目 15:算术表达式求值【问题描述】 在计算机中,算术表达式由常量、变量、运算符和括号组成。由于不同的运算符具有不 同的优先级,又要考虑括号,因此, 算术表达式的求值不可能严格地从左到右进

14、行。因而在 程序设计时,借助栈实现。【任务要求】 算法输入:一个算术表达式,由常量、变量、运算符和括号组成(以字符串形式输入)。为 简化,规定操作数只能为正整数,操作符为 +、 -* 、 / ,用 #表示结束。 算法输出:表达式运算结果。算法要点: 设置运算符栈和运算数栈辅助分析算符优先关系。 在读入表达式的字符序列的同 时,完成运算符和运算数的识别处理,以及相应运算。题目 16:内部排序算法比较问题描述】编制一个演示内部排序算法比较的程序。 利用随机函数产生 30000 个随机整数, 利用冒 泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、归并排序和堆排序等排序方 法进行排序,并统计

15、每一种排序上机所花费的时间。【任务要求】算法输入:以菜单的形式选择排序方法算法输出: 不同情况下关键字参加的比较次数和关键字的移动次数, 每一种排序上机所花费 的时间。算法要点:(1)利用随机函数产生 30000 个随机整数。(2)利用不同排序方法排序并统计两类次数,列表显示(3)程序以对话方式执行。题目 17:哈夫曼树的构造和哈夫曼编码 / 译码【问题描述】利用哈夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。 但是,这要求在发送端通过一个编码系统对待传数据预先编码, 在接收端将传来的数据进行 译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编 / 译码系统。试为这样的信息收发站写一个哈夫曼码的编 / 译码系统。【任务要求】一个完整的系统应具有以下功能:

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号