收藏 分享(赏)

数据结构课程课外实践任务.doc

上传人:dreamzhangning 文档编号:2692151 上传时间:2018-09-25 格式:DOC 页数:24 大小:250KB
下载 相关 举报
数据结构课程课外实践任务.doc_第1页
第1页 / 共24页
数据结构课程课外实践任务.doc_第2页
第2页 / 共24页
数据结构课程课外实践任务.doc_第3页
第3页 / 共24页
数据结构课程课外实践任务.doc_第4页
第4页 / 共24页
数据结构课程课外实践任务.doc_第5页
第5页 / 共24页
点击查看更多>>
资源描述

1、数据结构课程课外实践安排(2012-2013 学年第一学期)课外实践学时:32 学时课外实践目的:综合应用数据结构课程中所学的数据结构:线性表、栈、队列、串、数组、广义表、树、二叉树、图、查找表中的一种或多种数据结构完成一个较大问题的求解(其实这里的问题也并不太大,所用的数据结构可能是其中的多个,也可能是其中的一个两个) 。从而培养学生综合应用基本数据结构分析、解决实际问题的能力,并进一步加深对所学知识的理解和掌握。课外实践要求:1、课外实践以组为单位开展,每组 35 名同学,自由组合,确定组长一名。2、每组从附件 1 列出的题目中任意选择其中一个完成(鼓励大家选择对你自己而言有一定挑战性的题

2、目) ,每个题目最多由 3 组同学选做。强调独立思考,组内分工明确,每组自己完成。3、鼓励大家参考教材上、参考书上和所选题目相关的内容和算法。不鼓励大家一拿到实验题目就去网上或参考书上找相关程序源代码,通过思考该问题并最终解决该问题不仅可以锻炼大家,从而提高大家的水平,而且大家对该问题的解决也会有成就感!4、实现你所选题目要求的功能,并能够进行较完善友好的输入输出验证。5、完成你所选的课外实践题目后,就该题目给出设计报告(设计报告格式另给) ,并按时上交。6、每组同学须仔细阅读所选题目的要求,认真主动完成设计要求。有问题及时主动通过各种方式与教师联系沟通。同学们要发挥自主学习的能力,充分利用课

3、外时间,安排好课外实践的时间,并在设计过程中不断检测自己的计划完成情况,及时的向教师汇报。 课外实践按照教学要求需要思考和上机调试程序至少 32 学时,代码量要求在 6003000 行。7、课外实践的考核需要按组进行答辩,安排在第 16 周或 17 周进行。附件 1:数据结构课程课外实践可选题目一、运动会分数统计系统任务:参加运动会有 n 个学校,学校编号为 1n。比赛分成 m 个男子项目,和 w个女子项目。项目编号为男子 1m,女子 m+1m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。 (

4、m中。我们的模拟程序应该在每一个模拟分钟期间内更新下列信息,即每一次通过循环。 完成交款服务的总顾客数 这些顾客花费在排队等待的时间总和 顾客花费在排队等待的最长时间为了计算顾客等待的时间长度,我们需要存储“minute” ,作为这个客户队列数据项的一部分,表示顾客加入的时间。如果你使用程序模拟一列顾客流,试着完成下面的表格。请注意,平均等待时间是等待时间总和除以总的服务顾客数。时间(分钟) 总的顾客服务时间 平均等待时间 最长等待时间3060120480四、应用哈夫曼树实现文件的压缩实验目的:掌握二叉树的链式存储结构和常用算法。利用哈夫曼树设计最优压缩编码。实验内容:1) 编写函数,实现建立

5、哈夫曼树和显示哈夫曼树的功能。2) 编写函数,实现生成哈夫曼编码的功能。3) 编写主函数,从终端输入一段英文文本;统计各个字符出现的频率,然后构建哈夫曼树并求出对应的哈夫曼编码;显示哈夫曼树和哈夫曼编码。选做内容:修改程序,选择实现以下功能:4) 编码:用哈夫曼编码对一段英文文本进行压缩编码,显示编码后的文本编码序列;5) 统计:计算并显示文本的压缩比例;6) 解码:将采用哈夫曼编码压缩的文本还原为英文文本。算法说明:1) 二叉树和哈夫曼树的相关算法见讲义。2) 编码的方法是:从头开始逐个读取文本字符串中的每个字符,查编码表得到它的编码并输出。重复处理直至文本结束。3) 解码的方法是:将指针指

6、向哈夫曼树的树根,从头开始逐个读取编码序列中的每位,若该位为 1 则向右子树走,为 0 则向左子树走。当走到叶子节点时,取出节点中的字符并输出。重新将指针放到树根,继续以上过程直至编码序列处理完毕。4) 压缩比例的计算:编码后的文本长度为编码序列中的 0 和 1 的个数,原文本长度为字符数*8。两者之比即为压缩比。五、数据压缩【实验目的】1)调研数据压缩原理与相关算法的实现;2)实现一个压缩/解压缩程序【实验要求】1. 阅读相关资料,理解数据压缩的意义和过程。2. 调研几个著名的数据压缩算法,写一份调研报告,说明其算法及所使用的数据结构。3. 实现一个压缩/解压缩程序,算法任意。4. 程序要求

7、:控制台界面。首先实现对单文件压缩的功能。命令行格式:压缩: 程序名 -c 输入文件 输出文件名解压缩: 程序名 -d 输入文件 输出文件名里内容表示可选。控制台输出:压缩: 原始文件大小、压缩后文件大小、压缩比例、消耗时间解压缩: 解压前文件大小,解压后文件大小、压缩比例、消耗时间选做:1)将多个文件压缩到一个文件;2)检查压缩文件完整性,测试其能够完成解压缩;3)对文件测试,不压缩,输入其若压缩后的压缩率;4)列出压缩文件内所包含的文件名;4)实现对整个目录进行压缩的功能。文件格式:对压缩文件起一个后缀名。若在命令行中没指定输入文件的话,输出文件名应该是 输入文件名+.后缀名 的格式;若在

8、命令行中指定输出文件名的话,后缀也应自动加上。实现的压缩比例越高、压缩事件越短越好。六、HTML 文件中有序列表的语法树提取及基于树的检索【实验说明】HTML 语言用来描述 Web 文档的通用格式和布局。详细的介绍可以参照一些书本或者网上资料。HTML 中基本的语法单位称为标签。总的来说,标签用于指定内容的类别。对于每个类别,针对特定的内容,浏览器都有默认的显示方式。标签的使用语法是利用一对尖括号“parent;7) 当读到 时,整个树生成完毕,返回其头指针。针对前面示例的 html 文件,其语法树生成过程图示如下:1curParentcurNodeAnhui Province12curPar

9、entcurNode(a) 读到第一个,生成空的头节点 1 。 (b) 读到后第一个 ,生成第一个 子节点 2,并将其后内容作为节点内容。Anhui Province123City HefeicurParentcurNodeCity WuhuCity HefeiAnhui Province123 4curParentcurNode(c) 遇到 , curParent=curNode,准备 (d) 再次读到,生成以 curParent以 curParent 为根生成子树;读到,生 为根的子节点 4;读到,非成以 curParent 为根的子节点 3;读到 后第一个 ,curNode 指向的节点,

10、非后的第一个,curNode 指向 生成完毕。的节点生成完毕。 Anhui ProvinceCity WuhuCity Hefei123 4curParentcurNode Anhui ProvinceCity WuhuCity HefeiShanghai123 4curParentcurNode5(e) 读到,则以 curParent 为根的子树 (f) 读到,生成以 curParent 为根的生成完毕,curParent=curParent-parent, 子节点 5,内容为”Section 2”;再读到即 curParent 从 2 变为 1;再往下读到, ,curNode 节点生成结束

11、;读到此为后第一个,忽略掉,继续往后 ,以 curParent(节点 1)为根的读文件。 子树生成完毕;读到,整个树生成完毕,返回头指针。六、迷宫问题。传说在远古时候,米诺斯国王统治着爱琴海南端的克里特岛。他建造了一座有无数宫室的迷宫,在迷宫中喂养了一头人身牛头的恶兽米诺牛。为了供奉它,米诺斯要希腊的雅典每九年进贡七对童男女喂米诺牛。当时,雅典有位名叫忒休斯的王子,他不忍人民遭受这种灾难,毅然决定跟随第四批被进贡的童男女去克里特杀死米诺牛。在克里特,英勇的忒休斯赢得了米诺斯的女儿的爱慕。她交给忒休斯一个线团,让他按下面规则边走边放线:(1)每到一个岔口,找没有铺上线的路走;若找不到未铺上线的路

12、,就沿原来的路返回到前一个岔口。(2)不走已铺上两条线的路。用这种方法,忒休斯终于杀死米诺牛,胜利的走出迷宫七、学生数据结构成绩管理系统基本要求(1)学生信息及成绩的录入要求包括的学生信息有:学号、姓名、性别、出生日期、民族及数据结构成绩(具体内容可自行假设,至少录入 10 名以上学生)所录入的学生按学号散列存储(散列函数为:学号%5 取整,如 1002%5 =2) ,采用拉链法解决冲突。(2)学生成绩的查询要求根据提供的学号完成学生成绩的查询(必须采用哈希查找)(3)学生成绩的分段统计和排序输出统计出各分数段学生人数(60 分以下,6070,7180,.)采用任何一种排序方法,将学生成绩从高

13、到低排序输出八、哈希表应用问题描述针对某个集体中人名设计一个哈希表,使得平均查找长度不超过 R,并完成相应的建表和查表程序。基本要求假设人名为中国人姓名的汉语拼音形式。待填入哈希表的人名共有 300 个,取平均查找长度的上限为 2。哈希函数用除留余数法构造,用线性探测再散列法或链地址法处理冲突。 测试数据取读者周围较熟悉的 300 个人名。选作内容(1) 从教科书上介绍的集中哈希函数构造方法中选出适用者并设计几个不同的哈希函数,比较他们的地址冲突率(可以用更大的名字集进行实验) 。(2) 研究这 300 个人名的特点,努力找一个哈希函数,使得对于不同的拼音名一定不发生地址冲突。(3) 在哈希函

14、数确定的前提下尝试各种不同处理冲突的方法,考察平均查找长度的变化和造好的哈希表中关键字的聚集性。九、内部排序算法比较问题描述各种内部排序算法的时间复杂度分析结果只给出了算法执行时间的阶,或大概执行时间。试通过随机的数据比较各算法的关键字比较次数和关键字移动次数,以取得直观感受。基本要求(1) 对以下 10 种常用的内部排序算法任意选择 6 种进行比较:直接插入排序;折半折入排序;二路插入排序;希尔排序;起泡排序;快速排序;简单选择排序;堆排序;归并排序;基数排序。(2) 待排序表的表长不小于 100;其中的数据要用伪随机数产生程序产生;至少要用 5 组不同的输入数据作比较;比较的指标为有关键字

15、参加的比较次数和关键字移动次数(关键字交换计为 3 次移动) 。测试数据由随机产生器决定。实现提示主要工作是设法在程序中适当的地方插入计数操作。程序还可以包括计算几组数据得出结果波动大小的解释。注意分块调试的方法。十、校园导游程序 问题描述用无向网表示安阳师范学院校园景点或建筑物平面图,图中顶点表示主要景点或建筑物,存放景点的编号、名称、简介等信息,图中的边表示景点间的道路,存放路径长度等信息。要求能够回答有关景点介绍、游览路径等问题。基本要求(1) 查询各景点的相关信息;(2) 查询图中任意两个景点间的最短路径。(3) 查询图中任意两个景点间的所有路径。(4) 增加、删除、更新有关景点和道路

16、的信息。(5) 求多个景点的最佳(最短)游览路径。十一、实现第 7 章图中的部分算法,这些算法至少包括以下两组:(1) 深度和广度优先搜索遍历图;(2) 构造最小生成树的两种算法(3) 拓扑排序算法;(4) 求解关键路径;(5) 求解最短路径。十二、合理设计手机键盘【题意描述】我们的手机键盘上将 26 个字母如下左图设置在 8 个键盘上,但每个字母的按键频率是不同的,因此如果按照右图的方式设置字母在键盘上的相对位置可能会使所有字母的按键频率与按键次数乘积之和达到最小,从而更加方便客户使用。我们的任务是根据输入的键盘数和字符数及每个字符的使用频率来确定最合理的分配方式,使分配后所有字符的频率和按

17、键次数的乘积之和最小。在每个键盘上,处于第 i 个位置上的字符按键次数为 i,在分配的过程中我们不能更改字符的相对位置。该题目详细描述如下:I-KeyboardTime Limit: 2000MS Memory Limit: 32768KTotal Submissions: 3235 Accepted: 1690DescriptionMost of you have probably tried to type an SMS message on the keypad of a cellular phone. It is sometimes very annoying to write lon

18、ger messages, because one key must be usually pressed several times to produce a single letter. It is due to a low number of keys on the keypad. Typical phone has twelve keys only (and maybe some other control keys that are not used for typing). Moreover, only eight keys are used for typing 26 lette

19、rs of an English alphabet. The standard assignment of letters on the keypad is shown in the left picture: 12abc3def4ghi5jkl6mno7pqrs8tuv9wxyz*0space#12abcd3efg4hijk5lm6nopq7rs8tuv9wxyz*0space#There are 3 or 4 letters assigned to each key. If you want the first letter of any group, you press that key

20、 once. If you want the second letter, you have to press the key twice. For other letters, the key must be pressed three or four times. The authors of the keyboard did not try to optimise the layout for minimal number of keystrokes. Instead, they preferred the even distribution of letters among the k

21、eys. Unfortunately, some letters are more frequent than others. Some of these frequent letters are placed on the third or even fourth place on the standard keyboard. For example, S is a very common letter in an English alphabet, and we need four keystrokes to type it. If the assignment of characters

22、 was like in the right picture, the keyboard would be much more comfortable for typing average English texts. ACM have decided to put an optimised version of the keyboard on its new cellular phone. Now they need a computer program that will find an optimal layout for the given letter frequency. We n

23、eed to preserve alphabetical order of letters, because the user would be confused if the letters were mixed. But we can assign any number of letters to a single key. InputThere is a single positive integer T on the first line of input. It stands for the number of test cases to follow. Each test case

24、 begins with a line containing two integers K, L (1 1, either Pi = Pi-1+1 or Pi = 1 there are at most K numbers Pi such that Pi = 1 the sum of products SP = F1*P1+F2*P2+.+FL*PL is minimal for any other sequence Q meeting these criteria and with the same sum SQ = SP, there exists such M, 1 QM. The ou

25、tput for every test case must start with a single line saying Keypad #I:, where I is a sequential order of the test case, starting with 1. Then there must be exactly K lines, each representing one letter, in the same order that was used in input. Each line must contain the character representing the

26、 key, a colon, one space and a list of letters assigned to that particular key. Letters are not separated from each other. Print one blank line after each test case, including the last one. Sample Input18 2623456789ABCDEFGHIJKLMNOPQRSTUVWXYZ33715891575161462129717731904298912320915881513299632691080

27、1212726308343681334518752427733871Sample OutputKeypad #1:2: ABCD3: EFG4: HIJK5: LM6: NOPQ7: RS8: TUV9: WXYZ十三、二叉排序树的应用( 基于二叉排序树的个人通信录)在日常生活中,个人通信录是我们不可少的,不管是纸式的个人通信录 还是我们手机中的个人通信录,查寻是其最基本的操作,几乎所有的操作都是在查寻的基础上进行的,所以,查寻时间的快慢很大程度上决定了整个通信录的性能。所以,一个有着良好界面、查寻速快的通信录,是人们所追求的。本设计应用折半查寻法 的技术思想进行查寻,从本思想出发,可以有两种

28、数据组织方式:一是应用链表进行组织数据,由于折半查寻法的特殊性,所要进行查寻的数据列必须是有序的数据列,这样要求对数据列进行排序。出于系统实时查寻的考虑,每次对通信录进行改变后都得进行重新排序,这样才能保证数据列是实时有序的。这样当操作量大时,排序所消耗的时间对整个系统有很大的影响。 二是应用二叉排序树来组织数据,由于二叉排序树是应用折半查寻法思想进行对数据进行存储的,所以,其左孩子大于双亲结点、右孩子小于双亲结点(或者左孩子小于双亲结点、右孩子大于双亲结点),这样就可以应用折半查寻法的思想进行查寻,从而减少对排序时所消耗的时间。 本设计采用第二种方法,即应用二叉排序树进行组织数据,在此基础上

29、进行对个人通信录的各种操作。由于删除操作是本设计的重点,删除操作的成功与否直接影响到整个系统的成败,所以在此进行详细分析一下删除操作的实现。此功能函数主要应用于删除将要进行删除的记录,此操作较其它几个操作难一点,同时也是此次设计的重点,所以,本函数的成败可以直接影响到本次设计的成败,同时,在进行二叉排序树进行组织时,如果不从系统的整体进行考虑,只想到简单地实现删除功能,将会出现错误。 在设计初期,由于没有考虑所有可能的情况,所以在进行删除最后一个结点时,总会出现内存不能引用的错误。最后想到应用浪费一个结点空间的技术进行处理此问题,就是根结点用来保存二叉排序树的某些信息,而不保存记录,与我们单链

30、表中的头结点一样,这样做解决了上面所说的问题,同时在进行查寻双亲结点时也带来了很大的方便。 有关二叉排序树的删除的有关问题,请读者参考相关的参考文献 ,在此不再进行说明,本节重点在于说明本课程设计中有关删除的问题。 在本设计中,删除的首要条件是找到将要进行删除结点的双亲结点,由于根结点不用于存储记录,所以,可以不用进行判断根结点的情况,进行查寻双亲结点时,从根结点开始,首先进行判断根结点的左右子树是否为空,如果根结点的左右子树为空,则返回 NULL ,如果根结点的左子树(右子树)不为空,则将其左子树(右子树)的记录的学号与将要进行删除的学号进行比较,如果相等,则返回根结点;否则进行比较,如果左

31、子树(右子树)不为空,且左子树(右子树)的学号大于(小于)要进行删除的学号,则进行递归在左子树(右子树)中进行查寻,直到查寻到或者当前结点的左右子树为空时结束。如果当前结点的学号与要进行删除的学号不相等,且当前结点的左右子树为空,则返回空,结束查寻过程。 经过对双亲结点的查寻,如果没有此记录,则进行提示,否则进行删除操作 1 5 ,在进行删除时,有以下几种可能,以下操作中假设每次把要进行删除结点进行删除后,同时也释放了此结点所占用的内存空间,防止内存在运行过程中丢失。 第一:要进行删除的结点为叶结点,直接把其从二叉排序树中进行删除。 第二:此结点只有左子树或者右子树,这种情况下只需将只需把此结

32、点的左子树或者右子树替换为双亲结点的左子树。 第三:此结点有左子树同时有也右子树,此种操作比较复杂,其中有两种方法进行删除,本课程设计中应用的方法是从某子树中找出一个结点(假设为 Temp ),将其值代替要进行删除结点的值,再把 Temp 结点进行删除。 十四、DNA 分子的最佳比对问题描述:DNA 分子是人类遗传信息的载体,它间接地指导蛋白质的合成。DNA 分子是由四种核苷酸组成的长链,这四种核苷酸分别是腺嘌呤核苷酸(用 A 代表) 、鸟嘌呤核苷酸(用G 代表) 、胞嘧啶核苷酸(用 C 代表)和胸腺嘧啶核苷酸(用 T 代表) 。习惯上用一个字符集为A,T ,C,G的字符串来表示一个 DNA

33、分子序列,如 CGTTAGA。在生物进化过程中,DNA 分子可能发生各种各样的突变。这种突变形成了生物遗传信息的改变,从而使生物得以分化,构成了生物的多样性。主要的突变有三种:(1)在一个DNA 序列中插入一个新的核苷酸, (2)DNA 序列中丢失了一个核苷酸, (3)DNA 序列中的某个核苷酸被另一个核苷酸所取代。所谓两个 DNA 序列的一个比对是寻找一种排列方式,使得两个 DNA 序列在同样的位置上有相同的核苷酸,而若在同样的位置上两个 DNA 序列的核苷酸不同,则是由三种突变之一得到。例如,对两个 DNA 序列 T =ATCAG,T =ACTAG,可以按如下方式比对,12比对 1: T

34、T 2A AT - (“-”表示空白)C C- T A AG G也可以按如下方式比对比对 2: T T12A AT C C T A AG G如果两个 DNA 序列在相同的位置上有越多相同的核苷酸对,则表明它们之间越相似,即它们存在功能上的相似性和进化史上的亲缘关系。对于两个 DNA 序列的一个比对,规定如下得分方式:(1)一个同样的位置上有相同的核苷酸对,则可得 1 分;(2)一个同样的位置上有不同的核苷酸对,则得 0 分;(3)如果在某个位置上一个序列有核苷酸,而另一个序列在该位置上为“-” ,则得-2 分。例如,比对 1 的得分是 0 分,比对 2 的得分是 3 分。编程任务:对于两个 D

35、NA 序列,寻找一种比对方式,使得它们的得分最高。数据输入:输入数据由文件名为 INPUT3.*的文本文件提供,共有 2 行。第 1 行为 DNA 序列 T , 第 2 行为 DNA 序列 T 。序列的长度不大于 5000。序列中1的字母是英文小写或者大写字母。结果输出 :程序运行结束时,在屏幕上输出两个 DNA 序列比对的最高得分。输入文件示例 输出示例INPUT3.001AtcagActag3Human Gene Functions Time Limit:1000MS Memory Limit:10000KTotal Submit:2255 Accepted:1440Description

36、It is well known that a human gene can be considered as a sequence, consisting of four nucleotides, which are simply denoted by four letters, A, C, G, and T. Biologists have been interested in identifying human genes and determining their functions, because these can be used to diagnose human diseas

37、es and to design new drugs for them. A human gene can be identified through a series of time-consuming biological experiments, often with the help of computer programs. Once a sequence of a gene is obtained, the next job is to determine its function. One of the methods for biologists to use in deter

38、mining the function of a new gene sequence that they have just identified is to search a database with the new gene as a query. The database to be searched stores many gene sequences and their functions many researchers have been submitting their genes and functions to the database and the database

39、is freely accessible through the Internet. A database search will return a list of gene sequences from the database that are similar to the query gene. Biologists assume that sequence similarity often implies functional similarity. So, the function of the new gene might be one of the functions that

40、the genes from the list have. To exactly determine which one is the right one another series of biological experiments will be needed. Your job is to make a program that compares two genes and determines their similarity as explained below. Your program may be used as a part of the database search i

41、f you can provide an efficient one. Given two genes AGTGATG and GTTAG, how similar are they? One of the methods to measure the similarity of two genes is called alignment. In an alignment, spaces are inserted, if necessary, in appropriate positions of the genes to make them equally long and score th

42、e resulting genes according to a scoring matrix. For example, one space is inserted into AGTGATG to result in AGTGAT-G, and three spaces are inserted into GTTAG to result in GT-TAG. A space is denoted by a minus sign (-). The two genes are now of equal length. These two strings are aligned: AGTGAT-G

43、 -GT-TAG In this alignment, there are four matches, namely, G in the second position, T in the third, T in the sixth, and G in the eighth. Each pair of aligned characters is assigned a score according to the following scoring matrix. denotes that a space-space match is not allowed. The score of the

44、alignment above is (-3)+5+5+(-2)+(-3)+5+(-3)+5=9. Of course, many other alignments are possible. One is shown below (a different number of spaces are inserted into different positions): AGTGATG -GTTA-G This alignment gives a score of (-3)+5+5+(-2)+5+(-1) +5=14. So, this one is better than the previo

45、us one. As a matter of fact, this one is optimal since no other alignment can have a higher score. So, it is said that the similarity of the two genes is 14. InputThe input consists of T test cases. The number of test cases ) (T is given in the first line of the input file. Each test case consists o

46、f two lines: each line contains an integer, the length of a gene, followed by a gene sequence. The length of each gene sequence is at least one and does not exceed 100. OutputThe output should print the similarity of each test case, one per line. Sample Input2 7 AGTGATG 5 GTTAG 7 AGCTATT 9 AGCTTTAAA

47、 Sample Output1421 SourceTaejon 2001十五、二叉树的相关算法实现编程实现二叉树的创建、遍历(采用非递归算法)、线索化、能够进行简单的输入输出验证等。十六、图的实现问题描述:对于如下地图,实现图的基本算法。基本要求:1 以邻接表作交通图的存储结构,表示该图。2 求出该图的最小生成树3 针对用户所输入的两个城市、求出其最小距离,并输出所经历的城市及总距离。十七 成绩统计问题描述:给出 n 个学生的 m 门考试的成绩表,每个学生的信息由学号、姓名以及各科成绩组成。对学生的考试成绩进行有关统计,并打印统计表。基本要求1 按总数高低次序,打印出名次表,分数相同的为同一名

48、次;2 按名次打印出每个学生的学号、姓名、总分以及各科成绩。十八 算术表达式的求解问题描述:给定一个算术表达式,通过程序求出最后的结果。基本要求:1 从键盘输入要求解的算术表达式;2 采用栈结构进行算术表达式的求解过程;3 能够判断算术表达式正确与否;4 对于错误表达式给出提示;5 对于正确的表达式给出最后的结果;十九 编写一个五子棋的游戏程序问题描述:实现五子棋人与机对下的功能。基本要求:1、用矩阵来描述棋盘及对弈情况;2、通过输入行数、列数表示人所下的位置;3、由程序来确定电脑所下的位置;4、设计输、赢判断规则函数;5、显示每一步所对应的矩阵;二十 血缘关系判断问题描述:针对任意 2 个人

49、,判断 2 个人之间是否有血缘关系。基本要求:1 每个人都与父母具有直接血缘关系,针对每个人建立其血缘关系树;2 通过两棵树的遍历、比较判断 2 个人之间是否有血缘关系3 计算两个人血缘关系的远近、并输出两个人在遗传学上的距离(假设父子、母子关系的遗传学距离为 1)4 输出两棵树及运算结果二十一:长整数四则运算【问题描述】设计一个实现任意长的整数进行加法运算的演示程序。【基本要求】利用双向循环链表实现长整数的存储,每个结点含一个整型变量。任何整型变量的范 围是(2 15-l)(215-1) 。输入和输出形式:按中国对于长整数的表示习惯,每四位一组,组间用逗号隔开。【测试数据】(1) 0;0; 应输出 “0“ 。(2)2345,6789 ; 7654,3211; 应输出 “1,0000,0000“ 。 (3)9999,9999 ;1,0000,0000,0000; 应输出 “9999,0000,0001“ 。 (4) 1,0001, 0001;1,0001,0001; 应输出 “0“ 。(5) 1,0001, 0001;1,0001,0000; 应输出 “1“ 。(6) -99

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 高等教育 > 大学课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报