数据结构与算法课程设计 心得体会 学习体会(12).docx 立即下载
2025-08-27
约5.8千字
约10页
0
17KB
举报 版权申诉
预览加载中,请您耐心等待几秒...

数据结构与算法课程设计 心得体会 学习体会(12).docx

数据结构与算法课程设计心得体会学习体会(12).docx

预览

免费试读已结束,剩余 5 页请下载文档后查看

10 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

数据结构与算法课程设计心得体会学习体会(12)

第一篇:数据结构与算法课程设计心得体会学习体会(12)课程设计心得体会课程设计已经结束,怀着通过这次课程设计积累的信心与斗志,写下心得体会,为自己的奋斗留下痕迹,聊以缅怀。刚开始拿到课程设计的任务书时,看到是“单循环赛选手胜负序列求解问题”,题目只给了短短的几行内容:“有n个选手P1,P2,P3,„,Pn参加了的单循环赛,每对选手之间非胜即负。现要求求出一个选手序列P1',P2',P3',„,Pn',使其满足Pi'胜Pi+1'(i=1,„,n-1)”。我的理解就是每个选手各遭遇一次,获胜得1分,失败不得分。比赛结束时按照各选手之间的积分排名求解他们的胜负序列。后来经过老师的指导,又有了另外一种理解,即可以根据比赛过程中各选手之间的胜负关系产生胜负序列,不过这种方法产生的胜负序列可能不是唯一的,但是实际情况是比赛结束时一定会产生一种胜负序列。为此需要用合适的数据结构进行存储,来确定如何产生胜负序列,选取哪位选手作为第一名,假如该选手已经在序列中,在后面的筛选过程中,如何将该选手排除等一系列问题。有了思路后,就开始着手去设计算法,第一种情况采用的数据结构是类,将选手的编号、积分以及胜负过程中的积分处理等封装在类中。其中,以编号和积分作为私有成员,而设置编号、获胜处理、失败处理、获取积分、获取编号等作为公有成员。此时将该问题转化为对选手积分进行排序的问题。第二种情况采用的数据结构是有向图,将每个选手作为有向图的一个顶点,选手间的胜负关系作为有向弧,从箭头出发的一方作为获胜者,所以该问题转化为了有向图的深度遍历问题,即求解一条包含所有顶点的简单路径。在深度遍历过程中,以有向图的邻接矩阵作为存储结构。在本实验中,为了使功能更完善,还用到了磁盘文件。可以将参赛选手的人数、他们之间的胜负关系预先放进一个记事本中,运行程序时被读入,在处理后将胜负序列读出到另一个记事本中,并保存起来。这里会用到输入、输出文件流的成员函数。不过,在调试过程中出现了一些问题:①第一种情况时,以选手姓名作为私有成员时,由于权限问题,私有成员不能直接被调用,而主调函数中要求输入姓名,编译时一直出错。为了解决这个问题,另外定义了一个结构体,只放了选手姓名name,这样就可以使用了。在程序中只需要注意让选手姓名与积分对应起来就行了。同时,所得的胜负序列会读出到名为“比赛积分.txt”的文本文件中。②在试探的路径中出现了编号的重复,也就是说有些点在试探成功后又被试探了,这显然是错误的,分析可知,这是由于在对结点的试探成功后并没有修改相应的标志数组中的相应位置,即让visited[i]=1,导致了重复试探。在入栈函数Push()中加入了入栈功能,此问题得以解决。同理在测试失败时也应该修改相应的标志位置。③在从文件中读入参赛人数及胜负关系时,在记事本中格式为“4wffwfw”,第一次读入人数,在第二次读胜负关系时,“4”被重新读了一遍。为解决这个问题,老师指导时提及了fseek函数,但是从网上查到它只能在C语言中使用。因此,建立了两个记事本“Text1.txt”、“Text2.txt”,分别存放参赛人数和胜负关系,这样就不会出现问题了。临渊羡鱼,不如归而结网。这次课程设计给我的最大的印象就是如果自己有了兴趣,就动手去做,困难在你的勇气和毅力下是抬不了头的。从做这个课程设计开始无论遇到什么困难,我都没有一丝的放弃的念头。出于对知识的渴望,出于对新技术的好奇,出于对一切未知的求知,我完成了这次单循环赛课程设计,不过这只是我学习路上的驿站,我会继续学习,古语有云:学无止境!第二篇:数据结构与算法课程设计心得体会学习体会课程设计的心得体会刚一开始抽到题目,我一看觉得无从下手,由于那个时候很多课都还在进行着,也就是抽空思考一下思路,也到图书馆中借了相关的书来参考,但没有进行很深入的研究。课程设计开始的时候,我开始思考我该如何去求解,确定了算法之后,就开始写程序,修改错误,调试,直至完成,在这一过程中,让我学会了很多东西。在课程设计结束后,我对书本,也就是我们的教材的认识有了很大的提高。以前我觉得能看懂书上的知识,能写出算法就认为自己学的还可以。可是通过课程设计,通过我对书上知识的研究,我发现其实书上有很多东西是我没有领略到的。我的算法的核心思想就是图的深度优先搜索遍历,在用邻接表对图完成存储之后,我就开始仔细的看书上有关图的遍历的知识,包括深度优先搜索遍历和广度优先搜索遍历,就那么几页纸,我看了不知道多少遍。刚一开始看一下,觉得自己会了,然后做程序,遇到问题再拿书看,没看一次我对算法的理解就更进了一步。通过这次课程设计,让我明白了书上的知识看似是很有限的,但它蕴含的东西值得我们去花更多的时间去研究。学知识不能只学表面的知识,做出一个深度优
查看更多
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

数据结构与算法课程设计 心得体会 学习体会(12)

文档大小:17KB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
全场最划算
12个月
199.0
¥360.0
限时特惠
3个月
69.9
¥90.0
新人专享
1个月
19.9
¥30.0
24个月
398.0
¥720.0
6个月会员
139.9
¥180.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用