2022年网络组课程方案报告 .pdf





《2022年网络组课程方案报告 .pdf》由会员分享,可在线阅读,更多相关《2022年网络组课程方案报告 .pdf(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、个人资料整理仅限学习使用陕 西 科 技 大 学 电 信 学 院 数 据 结 构 课 程 设 计 报 告名称:“校园之星”投票系统班级:网络 101组别:第四组成员:李昀隆 霍杏 吕佳骏 赵晨 胡波 杨康宁指导教师 :赵晓学年学期 : 2018 2018 学年 第 一 学期2018 年 12 月 28 日摘 要本课程设计题目为校园之星投票系统,这个系统可以为你心中的校园之星投票及进行评价,并可以查看学生的得票数和评价情况。另外,系统还可以生成截止某一时刻的投票情况统计清单。我们主要运用了数据结构的两块知识:一个是哈希表的相关内容,其中具体包括哈希表的创建、查找、插入、冲突处理。输入的学生拼音名字
2、的ASCII 码值之和对哈希表长取余,精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 16 页个人资料整理仅限学习使用获得哈希地址。投票时,进行哈希查找,若查找成功,则票数加一,若查找失败,则将其姓名插入到哈希表中。另一个是有关文件的创建、读写的相关内容。系统运行时会自动生成一个.txt的文件,将学生姓名及票数都记录在内,以便随时调出查看。主函数中用switch语句实现多分枝选择,来实现不同的功能。本程序的优点在于用哈希表来进行查找文件中的内容,这样调用的时候很方便,而且当面对群体较广,上榜学生较多时,查找速度会比较快。关键字: 哈希表
3、;文件;投票;查看;目录精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 16 页个人资料整理仅限学习使用数据结构课程设计报告一 需求分析1、程序的功能校园之星投票系统主要实现了四个功能:1给您心中的校园之星投票和评价2.查看某位学生的票数3.查看某位学生获得的评价4.截止目前投票情况给您心中的校园之星投票和评价功能中,实现投票和评价功能,我们运用了投票函数 vote,在此函数中包括了哈希表的查找HashSearch(ht,x,在哈希表查找中地址为正,则找到这个人,投一票,地址为负时则把地址转正,增加此人,并把新的投票信息 付 给 此 人
4、 , 加 入 到 哈 希 表 中 。 在 投 票 函 数 中 还 调 用 了 写 文 件 函 数WriteBoard(filename,x,addr,将学生的投票信息写入到txt 格式的文件中。查看某位学生的票数的功能中,运用的是Dispvote 函数。此函数中主要调用的是哈希查找 HashSearch(ht,x ,实现对某位同学票数的查看。查看某位学生的评价功能中,运用的是Dispevaluate函数,其原理同DispVote 函数相同。截止目前投票情况功能中,运用了函数Dissituation,其主要是通过一个循环来遍历哈希地址将所有学生的得票情况打印出来。2、输出形式给您心中的校园之星投
5、票和评价功能中,投票人输入学生姓名和评价,即可,输出,恭喜投票成功。查看某位学生的票数和评价两个功能中,投票人输入学生的名字查找该同学,查找成功则显示该同学的相关信息,否则输出对不起,没有您要查找的学生,请检查输入是否正确 ,返回主菜单重新输入,若输入无误,则该生还没有上榜,您可以返回主菜单为其投票哦。截止目前投票情况中会输出目前为止所有的投票信息声明中会输出程序相关的声明。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 16 页个人资料整理仅限学习使用3、初步测试计划小组内每个人对自己所编写的函数进行测试,成功后合并到一起进行调试。对
6、所出现的问题集体进行讨论,然后修改再运行,直至整个程序运行成功。修改时我们主要用了printf打印法,缩小范围,查找出错地方。程序中投票人只需输入数字1,2,3,4,5,)便可选择想要实现的功能。在case 1 中投票者需输入所喜欢学生的拼音名字,以及对他的评价;在 case2 ,case3中投票人输入学生的拼音名字即可查看其得票数和他人的评价。初步测试成功。二、概要设计一、子函数功能介绍1、 建立文件 CreateBoard :初始化所有学生的得票信息 2、 读取文件内容ReadBoard :生成的文件为二进制随机存取文件,文件内容为上榜学生的信息,即 DataType 类型的数据。文件中的
7、记录按照哈希地址来存放。3、 写文件 WriteBoard :把修改后的学生信息或新上榜的学生信息写入文件中的指定位置。4、 哈希表的创建 CreateHash :首先将表中各节点的关键字清空,使其地址为开放的;然后调用插入的算法将给定的数据元素序列items一次插入哈希表中。5、 哈希表的插入HashInsert:首先调用查找算法在哈希表中待插入的数据元素,若在表中找到待插入的数据元素,则不必插入;若在表中没找到待插入的数据元素,此时查找算法给出一个单元空闲的哈希地址,则将待插入的数据元素插入到该哈希地址对应的空闲单元中。6、哈希表的查找 HashSearch :哈希表的查找过程与创建哈希表
8、过程类似7、哈希函数 HashFunc :采用除留余数法构造哈希函数8、冲突处理函数 Collision:在开放定址法中,选用线性探查法处理冲突9、投票函数Vote:为学生投票分为两种情况:一是学生已经在榜上,那么给学生的票数加一;二是学生不在榜上,那么把学生插入哈希表中,并保存在文件中。10、查看学生得票情况DispVote:根据学生的名字在哈希表中查找学生,并显示学生的得票数。11、查看学生的评价Dispevaluate:根据学生的名字在哈希表中查找学生,并显示他人对该生的评价。12、截至目前投票情况查询函数Dissituation 13、声明函数 claim 精选学习资料 - - - -
9、 - - - - - 名师归纳总结 - - - - - - -第 4 页,共 16 页个人资料整理仅限学习使用II 、函数的调用关系三,小组分工情况起初我们在一起讨论了课设题目,需要用到的数据结构知识,算法,列出了整体框架,流程按照框架分好了每个人的任务,下页所示。分头去查阅资料,完成各自的任务,随时在讨论在一起合程序,运行调试。一起努力,看到了黎明的曙光。李昀隆 Main 函数调试及后期美化处理霍杏哈希表创建相关函数吕佳骏文件的读写函数赵晨票数,评价查询函数精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 16 页个人资料整理仅限学习使
10、用胡波创建榜单函数,投票情况显示杨康宁声明,花边函数3 详细设计、函数流程图精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 16 页个人资料整理仅限学习使用二,用到的数据结构的知识及相关数据结构的描述形式1、哈希表在线性表、树等结构中,记录在结构中的相对位置是随机的,和记录的关键字之间不存在确定的关系,因此,在结构中查找记录时需进行一系列和关键字的比较。理想的情况是不经过任何比较,一次存取便能得到所查记录,那就必须在存储的记录位置和它的关键字之间建立一个确定的对应关系,使每个关键字和结构中一个唯一的存储位置相对应,这个对应关系即为开始输
11、入 choice 输入x.pinyin 输入x.pingjia x.pinyin 输入x.pinyin 声明函数结束投 票 函数显示评价函数显 示 票数函数输入 k 结 束K=0 K 为任意数字显 示 投票 情 况函数1 2 3 4 5 0 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 16 页个人资料整理仅限学习使用哈希函数,按这个思想建立的表称为哈希表。2、哈希函数的构造除留余数法构造哈希函数:取关键字被某个不大与哈希表表长m 的数 p 除后所得余数为哈希地址。即 H;用 fclose 关闭文件: fclose(fp。用二进制方式
12、向文件读写一组数据: fread(buffer,size,count,fp,fwrite(buffer,size,count,fp。用 fseek 改变文件位置标记:fseek(文件类型指针,位移量,起始点。写入的数据存储在生成的txt 文件中。程序如下#include stdio.h #include malloc.h #include string.h #include stdlib.h #include / 清屏函数所在头文件 / #define HASHSIZE 41 #define NULLKEY 0 typedef int KeyType。typedef struct KeyTyp
13、e key 。 char pinyin20。 char pingjia50。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 16 页个人资料整理仅限学习使用DataType。typedef struct Node DataType data。 struct Node *left,*right。BSTNode,*BSTree。typedef struct DataType data 。int times。HashItem,HashTableHASHSIZE 。/*获得哈希地址 */ 根据以拼音表示的学生姓名计算哈希地址 int HashF
14、unc(char key /实参为 x.pinyin /* key为学生的姓名 */ int addr=0,i=0。 while(keyi!=0 addr+=(intkeyi。i+ 。/key为拼音的 ASCII 码值 return addr % HASHSIZE。 /*冲突处理 */int Collision(int d return(d+1%HASHSIZE。 /*哈希查找 */int HashSearch(HashTable ht,DataType x int addr。 addr=HashFunc(x.pinyin。 if (strcmp(htaddr.data.pinyin,NULL
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年网络组课程方案报告 2022 网络 课程 方案 报告

限制150内