学生成绩管理系统(线性表版)
数据结构毕业设计论文题目整理

数据结构课程设计题目1.飞机订票系统(限1 人完成)(顺序或链式存储)任务:通过此系统可以实现如下功能:录入:可以录入航班情况(数据可以存储在一个数据文件中,数据结构、具体数据自定)查询:可以查询某个航线的情况(如,输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓);可以输入起飞抵达城市,查询飞机航班情况;订票:(订票情况可以存在一个数据文件中,结构自己设定)可以订票,如果该航班已经无票,可以提供相关可选择航班;退票:可退票,退票后修改相关数据文件;客户资料有姓名,证件号,订票数量及航班情况,订单要有编号。
修改航班信息:当航班信息改变可以修改航班数据文件要求:根据以上功能说明,设计航班信息,订票信息,客户信息的存储结构,设计程序完成功能;2.宿舍管理查询软件(限1 人完成)任务:为宿舍管理人员编写一个宿舍管理查询软件, 程序设计要求:采用交互工作方式建立数据文件,包括学生信息、宿舍信息、住宿信息,学生信息按关键字(姓名、学号)进行排序(排序方法自选,不能相同);查询: (用二分查找实现以下操作)按姓名查询按学号查询(用顺序查找实现以下操作)按房号查询3.校园导航问题(限1 人完成)设计要求:设计你的学校的平面图,至少包括10个以上的场所,每两个场所间可以有不同的路,且路长也可能不同,找出从任意场所到达另一场所的最佳路径(最短路径)。
要求:能增加场所4.图书借阅管理系统(限1 人完成)(顺序或链式存储)主要分为两大功能:1)图书管理(增加图书、查询图书、删除图书、图书借阅、还书);2)会员管理(增加会员、查询会员、删除会员、借书信息);5.学生成绩管理(限1 人完成)(顺序或链式存储)包括:课程信息,学生信息等;能增加课程或学生。
实现功能:输入、输出、插入、删除、查找、显示、保存、排序、退出。
6.活期储蓄帐目管理(限1 人完成)活期储蓄处理中,储户开户、销户、存入、支出活动频繁,系统设计要求:1)能比较迅速地找到储户的帐户,以实现存款、取款记账;2)能比较简单,迅速地实现插入和删除,以实现开户和销户的需要。
学生成绩管理系统(线性表版)

学年论文(数据结构 2015—2016 第一学期)题目: 数据结构课程设计作者:陈炳宏所在学院:信息科学与工程学院专业年级:信息安全14-1指导教师:刘淑娴职称:副教授2016年 1 月 4 日一.学生成绩管理系统 (1)1。
1需求分析 (1)1。
1.1程序分析: (1)1。
1.2执行方式: (1)1。
1.3 程序执行的命令包括: (1)1.1.4测试数据: (2)1.2概要设计 (2)1.2.1 线性表的抽象数据类型定义为: (3)1.2。
2 结点的抽象数据类型定义为: (3)1。
2。
3指针的抽象数据类型定义为: (3)1。
2.4本程序包含8个模块: (4)1。
3详细设计 (5)1.3.1 元素类型、结点类型和指针类型 (5)1.3.2 函数说明 (5)1。
3.3 功能函数 (5)1。
4 调试分析 (15)1.5 用户手册 (15)1。
6测试结果 (18)一.学生成绩管理系统1.1需求分析1.1。
1程序分析:本程序是一个基于线性表结构编写的学生成绩管理系统,学生可以进行包括学生信息建立、在不同位置插入学生信息、查询指定学生信息、删除指定学生信息和输出显示所有学生信息这五项功能,功能操作简单,效率高,可延展性强. 为保证信息的真实性,学生信息中学号长度num<=11,姓名长度name〈=8,性别gender<=3,成绩仍意输入,并且学号和成绩只能为数字,否则程序出错。
1。
1。
2执行方式:本程序以用户和计算机的对话方式执行,即在计算机终端上显示7个共能选择的“提示信息"之后,由用户在键盘上输入本程序中规定的功能指令;相应的输人数据(并能滤去输入中的非法字符)和显示信息来处理结果。
1.1.3 程序执行的命令包括:(1)学生信息链表的建立;建立后仍意建继续输入,n和N退出;(2)插入学生信息;输入插入的位置;(3) 查询学生信息;选择两种方式之一查找并查询;(4)删除学生信息;选择两种方式之一查找并删除;(5)修改学生信息;选择两种方式之一查找并修改;(6) 输出所有学生信息;(7)退出管理系统.1.1.4测试数据:(1)建立三个学生信息:学号(11)姓名(8)性别成绩20141305210,cc,n,8920141302399,sxz,w,9920151432596,sad,n,88(2) 插入一个学生信息:学号(11)姓名(8)性别成绩2016,scs,n,79输入插入位置:2(3) 查询学生信息:按1选择学号查询,输入学号:20141305210按2选择姓名查询,输入姓名:scz(4) 删除学生信息:按2选择姓名删除,输入姓名:cc(5)修改学生信息:按1选择学号修改,输入学号:20141302399输入修改后的数据:学号(11)姓名(8) 性别成绩20141312399,scz,w,691。
数据结构课程设计可选题目

数据结构课程设计可选题目一、课程设计的目的学习数据结构与算法的最终目的是解决实际的应用问题,特别是非数值计算类型的应用问题。
课程设计要求同学独立完成一个较为完整的应用需求分析,在完成设计和编程大型作业的过程中,深化对数据结构与算法课程中基本概念、理论和方法的理解;训练综合运用所学知识处理实际问题的能力,强化面向对象的程序设计理念;使同学的程序设计与调试水平有一个明显的提高。
二、数据结构课程设计可选题目1. 运动会分数统计(限1 人完成)任务:参加运动会有n个学校,学校编号为1……n。
比赛分成m个男子项目,和w个女子项目。
项目编号为男子1……m,女子m+1……m+w。
不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。
(m<=20,n<=20)功能要求:1) 可以输入各个项目的前三名或前五名的成绩;2) 能统计各学校总分,3) 可以按学校编号或名称、学校总分、男女团体总分排序输出;4) 可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校;5) 数据存入文件并能随时查询;6) 规定:①输入数据形式和范围:可以输入学校的名称,运动项目的名称;②输出形式:有中文提示,各学校分数为整形;③界面要求:有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求。
④存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中。
(数据文件的数据读写方法等相关内容在c语言程序设计的书上)请在最后的上交资料中指明你用到的存储结构;⑤测试数据:要求使用a.全部合法数据;b.整体非法数据;c.局部非法数据进行程序测试,以保证程序的稳定。
测试数据及测试结果请在上交的资料中写明。
2. 飞机订票系统任务:通过此系统可以实现如下功能:⑴录入:可以录入航班情况(数据可以存储在一个数据文件中,数据结构、具体数据自定)⑵查询:可以查询某个航线的情况(如,输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓);⑶可以输入起飞抵达城市,查询飞机航班情况;⑷订票:(订票情况可以存在一个数据文件中,结构自己设定)可以订票,如果该航班已经无票,可以提供相关可选择航班;⑸退票:可退票,退票后修改相关数据文件;⑹客户资料有姓名,证件号,订票数量及航班情况,订单要有编号。
高校学生成绩管理系统数据结构设计

S se Da a,tu t r sg fCo lg y t m t S r cu eDe i n o l e e
S u n ro m a c a g m e t t de tPe f r n e M na e n
YANG —i g Ke ln
( o p t n n r t nIstt o eh o g f hn q o a ol eH n nS agl 70 0P C C m u r dI omao tue f cnl yo agi N r l l g , e a hn qu 6 0 R ) ea f i ni T o S u m C e 4
d s e i l n t e su e tr g s ain s c in, t d n c iv me t mo i e e i d man y i t d n e i r t e t n g h t o o s e ta h e e n d f d,a d ta s f  ̄ u i n nc p r i
系统包 括 的内容较 多 , 系统主 要完 成 以下功能 : 本
《算法设计综合实训》题目讲解

算法设计综合实训题目0.逆序数字(借助栈)编写一个函数,接收一个4位整数值,返回这个数中数字逆序后的结果值。
例如,给定数7631,函数返回1367.输入:第一行一个正整数T(T<=10),表示有T组测试数据; 以下T行,每行一个非负的整数N。
输出:共T行,对于每组输入数据输出一行,即数字逆序后的结果值。
样本输入:3763110185158样本输出:1367810185151.人见人爱A+B这个题目的A和B不是简单的整数,而是两个时间,A和B 都是由3个整数组成,分别表示时分秒,比如,假设A为34 45 56,就表示A所表示的时间是34小时 45分钟 56秒。
输入:输入数据有多行组成,首先是一个整数N,表示测试实例的个数,然后是N行数据,每行有6个整数AH,AM,AS,BH,BM,BS,分别表示时间A和B所对应的时分秒。
题目保证所有的数据合法。
输出:对于每个测试实例,输出A+B,每个输出结果也是由时分秒3部分组成,同时也要满足时间的规则(即:分和秒的取值范围在0-59),每个输出占一行,并且所有的部分都可以用32位整数表示。
样本输入:21 2 3 4 5 634 45 56 12 23 34样本输出:5 7 947 9 302.敲七【问题描述】输出7和7的倍数,还有包含7的数字例如(17,27,37...70,71,72,73...)【要求】【数据输入】一个整数N。
(N不大于30000)【数据输出】从小到大排列的不大于N的与7有关的数字,每行一个。
【样例输入】20【样例输出】714173.统计同成绩学生人数问题【问题描述】读入N名学生的成绩,将获得某一给定分数的学生人数输出。
【要求】【数据输入】测试输入包含若干测试用例,每个测试用例的格式为第1行:N第2行:N名学生的成绩,相邻两数字用一个空格间隔。
第3行:给定分数当读到N=0时输入结束。
其中N不超过1000,成绩分数为(包含)0到100之间的一个整数。
数据结构线性表应用

数据结构线性表应用在计算机科学领域中,数据结构是一门至关重要的学科,它为我们提供了高效组织和管理数据的方法。
其中,线性表作为一种基本的数据结构,具有广泛的应用场景。
线性表是由零个或多个数据元素组成的有限序列。
这些数据元素在逻辑上是线性排列的,也就是说,它们之间存在着一种顺序关系。
常见的线性表实现方式有顺序表和链表。
顺序表是一种采用连续存储空间来存储数据元素的线性表。
它的优点是可以随机访问元素,时间复杂度为 O(1)。
这意味着,如果我们知道元素在顺序表中的位置,就能够快速地获取到该元素。
想象一下,我们有一个学生成绩的顺序表,要查找第 10 个学生的成绩,直接根据索引就能迅速找到。
顺序表在需要频繁进行随机访问的场景中表现出色,比如在数据库中存储数据时。
然而,顺序表也有它的局限性。
当需要插入或删除元素时,如果插入或删除的位置不是在表尾,就需要移动大量的元素,时间复杂度为O(n)。
这在数据量较大时,可能会导致性能下降。
相比之下,链表则在插入和删除操作上具有优势。
链表中的每个节点包含数据元素和指向下一个节点的指针。
当进行插入或删除操作时,只需要修改相关节点的指针即可,时间复杂度为 O(1)。
比如,在一个购物车的链表中,添加或删除商品时,不需要移动其他商品的位置,操作效率很高。
线性表在日常生活中的应用比比皆是。
以我们常见的排队为例,排队的人群可以看作是一个线性表。
每个人按照先后顺序排列,新加入的人排在队尾,离开的人从队首离开。
这种先入先出的特性,与线性表中的队列结构相似。
在计算机程序中,线性表也有广泛的应用。
比如,在文本编辑软件中,我们输入的字符序列可以看作是一个线性表。
当我们进行插入、删除字符的操作时,就是对这个线性表进行修改。
再比如,在操作系统的进程管理中,进程可以按照它们的创建顺序或者优先级排列成一个线性表。
操作系统在调度进程时,需要根据线性表中的信息来决定哪个进程先执行,哪个进程后执行。
在软件开发中,线性表也常用于实现栈这种数据结构。
算法与数据结构课程设计任务书
算法与数据结构课程设计任务书1、实训意义和目的使学生巩固和加强《C语言程序设计》和《数据结构与算法》课程的理论知识。
使学生掌握C语言的基本概念、语法、语义和数据类型的使用特点。
使学生掌握C语言程序设计的方法及编程技巧,能正确使用C语言编写程序。
进一步理解和运用结构化程设计的思想和方法;学会利用流程图或N-S图表示算法。
使学生掌握调试程序的基本方法及上机操作方法。
掌握书写程设计开发文档的能力,使学生学会撰写课程设计总结报告。
课学生做毕业设计打好基础。
初步掌握开发一个小型实用系统的基本方法:结合实际应用的要求,使课程设计既覆盖知识点,又接近工程实际需要。
通过激发学习兴趣,调动学生主动学习的积极性,并引导他们根据实际编程要求,训练自己实际分析问题的能力及编程能力,并养成良好的编程习惯。
培养学生的创新能力和创新思维。
学生可以根据指导书和相关文献上的参考算法,自己设计出相应的应用程序。
培养学生良好的程序设计风格。
在实际编程中,为了提高编程质量,对空行、空格和注释均有要求。
学生在课程设计书写代码时,应该严格按要求处理,以便建立良好的程序设计风格。
2、实训目标及要求参加本课程设计的学生,应当认真完成本课程设计的全部过程。
并以最终课程设计成果来证明其独立完成各种实际任务的能力。
从而,反映出理解和运用本课程知识的水平和能力。
A、分析问题。
各种简单的与计算机有关的案例中所需要的输出结果,把大问题分解成小问题,使用自顶向下或类似设计方法给出模块化或计划。
B、提出算法执行特定任务。
模块表示为算法,使用自顶向下或伪代码等设计手段将模块细化成更详细的成分,清楚地表明顺序、选择和重复等到控制结构。
C、把一个算法变为用C语言编写的结构化程序。
D、用合适的测试方法检查程序是否符合最初的要求,为不合适数据设计错误陷阱,并提供错误信息来帮助用户。
E、写出清晰的用户文档,确保用户或者通过遵循程序中的指示或者使用程序设计者编写的文档能成功地运行程序。
线性表基本操作的编程实现
实验一线性表基本操作的编程实现【实验目的】线性表基本操作的编程实现要求:线性表基本操作的编程实现(2学时,验证型),掌握线性表的建立、遍历、插入、删除等基本操作的编程实现,也可以进一步编程实现查找、逆序、排序等操作,存储结构要求是链表存储结构(顺序存储结构建议作为课外实验完成),可以依次完成主要功能来体现功能的正确性,用菜单进行管理完成大部分功能,要求可以重复运行。
还鼓励学生利用基本操作进行一些更实际的应用型程序设计。
【实验性质】验证性实验(学时数:2H)【实验内容】1.线性表的链表存储,实现数据插入、删除运算。
为了体现功能的正常性,同时要编制数据输入函数和遍历函数,数据输入最好同时提供计算机自动产生数据。
2.其他建议改进的功能或细节:存储结构修改为循环链表、双向链表、循环双向链表等。
原始数据从文本文件读入。
结果存入文本文件【注意事项】1.开发语言:使用C++,不能使用C。
至于是否使用对象,初期可以不用,但是建议尽量尽快使用对象。
2.可以自己增加其他功能。
3.如果是自己开发的,请在程序界面上注明 ***原创。
如果是参考他人或改编他人的,则注明:*** 参考他人版。
希望大家诚实对待自己的努力。
如果有小组,版权页上写上全组人员。
4.在实验报告中也应该如实写出哪些程序功能是自己编的,哪些是参考别人的。
5.初始成绩全部学生都是不及格,然后逐步通过提交更好的版本来刷新成绩。
实验当日仅仅是不及格变为及格。
之后通过班长全班学生提交源代码,为了方便,建议把程序做成一个cpp。
之后在实验后的三天时间内提交实验报告。
过时不候。
结合实验当时的检测,实验后源代码的检测,实验报告的书写给出当次的成绩。
分为五级制。
程序提交在实验之后的三天里可以刷新。
但是一般不应该超过二次。
提交的程序必须要语法正确的。
目前由于老师的审查平台是c++6.0,所以为了统一起见,不接受其他平台的开发系统。
程序名一律类似为:T423-2-17-翁靖凯-链表实验程序.cpp所有信息之间为中横线。
线性表
n 1
n1 2 2
顺序表中插入操作的平均时间复杂度为O(n)
5. 删除
算法过程
序号 内容
0
1
a1
2
a2
3
a3
…
…
i-1
ai1
i
ai
i+1 ai1
…
…
n
an
n+1
maxsize -1
序号 内容
0
1
a1
2
a2
3
a3
…
…
i-1
ai1
i
ai1
i+1
ai 2
…
…
n-1
an
n
maxsize -1
删除前
删除后
把线性表(a1, a2, a3,......, an )顺序存放在内存中
地址 内存
b
a1
b+L
a2
b+2L
a3
…
…
…
…
b+(i-1)×L ai
… … b+(n -1)×L an
序号 0 1 2 3 … …
i
… … n
maxsize-1 顺序存储结构示意图
第二章 线性表
假设线性表的每个元素需占用L个存储单元,并以所占的 第一个单元的存储地址作为数据元素的存储位置(上图中 为b)。则线性表中第i+1个数据元素的存储位置LOC(ai+1) 和第i个数据元素的存储位置LOC(ai)之间满足下列关系:
第二章 线性表
例2-3、学生健康情况登记表如下:
姓 名 学 号 性 别 年龄 健康情况
王小林 790631 男 18 健康
学生成绩信息管理系统
题目:学生成绩信息管理系统用c语言实现学生管理系统,每个学生的信息包括:学号、姓名、性别、平时成绩、期末成绩。
系统能够完成学生信息的查询、更新、插入、删除、排序功能。
1、系统以菜单方式工作;2、学生信息录入功能(学生信息用文件保存)--输入;3、学生信息按条件查询功能—算法;●按学号查询●按姓名查询●按性别查询●按平时成绩查询●按期末成绩查询4、学生信息的删除与修改。
流程图:图1 函数功能模块图输入输出的要求(1)等候用户输入时,给出足够的提示信息,如:选择1,输入学生信息、选择2,查询学生信息。
(2)对输入值的类型,大小范围,字符串长度等,进行检查,对不合法的输入值给出出错信息。
(3)对删除数据给出方式,让用户进行确认删除。
1.概要设计1.抽象数据类型定义struct Student//创建结构体{………………………………};2.系统功能模块划分与设计(系统功能模块图)录入学生信息模块:输入1,判断学生信息是否存在,不存在输入1,继续上次输入,判断学生信息是否存在,运行结束。
输入2,判断学生信息是否存在,不存在输入2,清除数据重新输入,运行结束。
查询学生信息模块:查询学生信息,请输入选择查询方式。
输入1,按姓名查找学生信息输入2,按学号查找学生信息输入3,按性别查找学生信息输入4,按平时成绩查找学生信息输入5,按期末成绩查找学生信息运行结束删除学生信息模块:首先使用查询功能查询出需要修改/删除的记录,然后进行修改/删除操作无学生信息!请选项删除方式。
输入1,按照姓名删除输入2,按照学号删除运行结束修改,输出,排序学生信息输入4,修改学生信息,请输入需要修改的学生信息输入5,按姓名,成绩,平时成绩,期末成绩输出学生成绩。
输入6,将学生信息进行排序。
运行结束2.详细设计1、数据类型的定义struct Student//创建结构体{char num[20]; //学号char name[20]; //姓名char sex[5]; //性别int score; //平时成绩int QiMoscore; //期末成绩struct Student *next; //动态链表连接下一个结构体};2、主要模块的算法描述菜单模块通过while语句给出信息提示;清屏;绘制菜单(包含输入,查询,删除,修改,输出,排序);提示菜单选择并读入到变量;根据读入变量的值调用不同的模块函数;信息录入模块打开文件While(){ 清屏;按照提示输入各种信息;While显示各种信息;通过选择1.确认并继续 2.填写 3.修改 4.确认并返回选择四种功能;}}信息查询While(){ 通过菜单式的选择是学号查询还是姓名printf("\n----------请选择查询方式----------");printf("\n 1.按姓名查询");printf("\n 2.按学号查询");printf("\n 3.按性别查询");printf("\n 4.按平时成绩查询");printf("\n 2.按期末成绩查询");printf("\n 3.返回主菜单");printf("\n****************************\n");}如果选择学号进入学号模块通过输入学号If(学号存在继续){输出学生信息}Else 输出无此学生如果选择姓名进入姓名模块If(根据比较姓名判断学生是否存在){输出学生信息}Else 输出无此学生删除模块while( 继续删除 ){提示并读入待删除的学生的学生号;显示要删除的信息}删除成功信息修改模块输入要修改学生信息的学号:If (判断是否有此学生){ 菜单形式显示要修改的项目printf("\n1.姓名 2.学号 3.性别 4.平时成绩 5. 期末成绩 \n");printf("\n输入0可返回主页面 \n");}打开文件模块struct Student *read(){struct Student *p0, *p1, *head; FILE *fp;if ( ){return NULL;}if ( ){return 0;}do{if ( ){return NULL;}if ( ){return 0;}} while ( );}排序模块int paixu(struct Student *head)while(){while(){if(){}}}}}3.使用说明及编程体会使用说明该程序可以实现学生管理系统的信息排序、查询、更新、插入和删除。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
学年论文(数据结构 2015-2016 第一学期)题目:数据结构课程设计作者:陈炳宏所在学院:信息科学与工程学院专业年级:信息安全14-1指导教师:刘淑娴职称:副教授2016年 1 月 4 日一.学生成绩管理系统 (1)1.1需求分析 (1)1.1.1程序分析: (1)1.1.2执行方式: (1)1.1.3 程序执行的命令包括: (1)1.1.4测试数据: (2)1.2概要设计 (2)1.2.1 线性表的抽象数据类型定义为: (3)1.2.2 结点的抽象数据类型定义为: (3)1.2.3指针的抽象数据类型定义为: (3)1.2.4本程序包含8个模块: (4)1.3详细设计 (5)1.3.1 元素类型、结点类型和指针类型 (5)1.3.2 函数说明 (5)1.3.3 功能函数 (5)1.4 调试分析 (15)1.5 用户手册 (15)1.6测试结果 (17)一.学生成绩管理系统1.1需求分析1.1.1程序分析:本程序是一个基于线性表结构编写的学生成绩管理系统,学生可以进行包括学生信息建立、在不同位置插入学生信息、查询指定学生信息、删除指定学生信息和输出显示所有学生信息这五项功能,功能操作简单,效率高,可延展性强。
为保证信息的真实性,学生信息中学号长度num<=11,姓名长度name<=8,性别gender<=3,成绩仍意输入,并且学号和成绩只能为数字,否则程序出错。
1.1.2执行方式:本程序以用户和计算机的对话方式执行,即在计算机终端上显示7个共能选择的“提示信息”之后,由用户在键盘上输入本程序中规定的功能指令;相应的输人数据(并能滤去输入中的非法字符)和显示信息来处理结果。
1.1.3 程序执行的命令包括:(1) 学生信息链表的建立;建立后仍意建继续输入,n和N退出;(2) 插入学生信息;输入插入的位置;(3) 查询学生信息;选择两种方式之一查找并查询;(4) 删除学生信息;选择两种方式之一查找并删除;(5) 修改学生信息;选择两种方式之一查找并修改;(6) 输出所有学生信息;(7) 退出管理系统。
1.1.4测试数据:(1) 建立三个学生信息:学号(11) 姓名(8) 性别成绩20141305210,cc,n,8920141302399,sxz,w,9920151432596,sad,n,88(2) 插入一个学生信息:学号(11) 姓名(8) 性别成绩2016,scs,n,79输入插入位置:2(3) 查询学生信息:按1选择学号查询,输入学号:20141305210按2选择姓名查询,输入姓名:scz(4) 删除学生信息:按2选择姓名删除,输入姓名:cc(5) 修改学生信息:按1选择学号修改,输入学号:20141302399输入修改后的数据:学号(11) 姓名(8) 性别成绩20141312399,scz,w,691.2概要设计为实现上述程序功能,首先需要创建一个建立信息链表的函数,用于建立线性链表并对每个结点进行顺序的信息存储,然后创建其他五个函数,来依次实现插入、删除、查询、修改、输出信息。
其中插入信息需要利用循环使得指针循环指向指定结点,而删除、查询和修改均需要利用循环判断来找到指定数据。
1.2.1 线性表的抽象数据类型定义为:typedef struct {数据对象:char num,name,genger,score;数据关系:一对一的线性关系}DataType;基本操作:建立一对一的信息组1.2.2 结点的抽象数据类型定义为:typedef struct node{数据对象:DataType data;struct node *next;数据关系: *next∈data;}ListNode;基本操作:ListNode *findList(LinkList head);初始条件:链表指针类型的建立操作结果:查询函数为指针类型void changeNode(LinkList head);初始条件:查询函数调度成功,选择处有数据操作结果:新数据覆盖原数据来修改void delNode(LinkList head);初始条件:查询函数调度成功,选择处有数据操作结果:选中数据被释放void printList(LinkList head);初始条件:线性表存在且其余操作完成操作结果:输出显示最终数据1.2.3指针的抽象数据类型定义为:typedef {数据对象:ListNode *LinkList;LinkList head;数据关系:LinkList初始为head基本操作:LinkList createList(void)初始条件:建立一对一的信息组操作结果:建立信息链表函数1.2.4本程序包含8个模块:(1)主程序模块:BEGIN{main}初始化;SWITCH接受命令;处理命令;UNTIL 数据处理结束;END.(通过返回的菜单选择函数值进行功能选择并调用实现功能;)(2)菜单选择——单纯的选择功能序号并返回给主函数;(3)链表建立函数——实现顺序链表的建立并输入相应的数据进行结点的存储;(4) 插入信息函数——通过找到指定节点并进行结点插入的函数;(5) 查询信息函数——通过循环对输入的学号和姓名和已经存在数据一个一个往后对比来查找全部函数;(6) 删除信息函数——通过查询函数的基本原理,找到指定函数后,释放指定结点;(7) 修改信息函数——通过查询函数的基本原理,找到指定函数后,修改并覆盖原结点;(8) 输出所有信息函数——利用循环依次输出结点直到结点为空为止。
各模块之间的调用关系如图1:图1 模块调用关系图1.3详细设计1.3.1 元素类型、结点类型和指针类型TYPEDEF DataType—char,int;{元素类型}LinkList—head;{指针类型}ListNode—node;{结点类型}data:DataType;next:*node;END;ViSitProc—PROCEDURE(p:LinkType);{访问结点的过程类型}1.3.2 函数说明int menu_select();LinkList createList(void);void printList(LinkList head);int insertNode(LinkList head,ListNode *p,int i);ListNode *findList(LinkList head);void delNode(LinkList head);void changeNode(LinkList head);1.3.3 功能函数(1)建立链表函数LinkList createList(void){L istNode *p,*rear; //结点指针c har flag; //判断是否继续输入的标志h ead=(ListNode *)malloc(sizeof(ListNode));//头节点指针开辟内存r ear=head; //开始头与尾相同w hile(flag!='n'&&flag!='N'){p=(ListNode *)malloc(sizeof(ListNode)); //结点指针开辟空间printf("\n学号(11)姓名(8)性别成绩\n");scanf("%s%s%s%d",p->data.num,p->,p->data.gender,&p->data.score);rear->next = p;//让尾结点指向当前结点的下一结点,并且该节点赋值为p结点rear = rear->next; //尾结点指针指向下一结点printf("按n或N退出,按其他键继续输入\n");getchar();//对标志赋值判断是否继续scanf("%c",&flag);}r ear->next=NULL;//让尾结点的下一结点为空来结束链表r eturn head;//返回头指针}(2)插入信息函数int insertNode(LinkList head,ListNode *p,int i){L istNode *p1;i nt j=1;p1=head;i f(p1->next==NULL)//判断如果为空表,则插入作为第一个结点*//{if(i==0){p1->next=p;//让头节点的指向下一节点,且该结点为p结点p->next=NULL; //p结点的下一结点为空来结束链表}else return -1; //如果在空表情况下输入大于0位置,则返回-1。
}w hile((j<=i-1)&&(p1!=NULL))//找到第i-1个结点,p1指向该结点//{ p1=p1->next; j++; }i f(p1==NULL)//如果仍然没有合适的插入点,则返回-1//return -1;p->next=p1->next; //有就让p结点的下一位置指向当前结点的下一结点p1->next=p;//并重新让当前结点指向的下一节点变为p结点r eturn 0;}(3)查询信息函数ListNode *findList(LinkList head){L istNode *p;c har num[12];c har name[9];i nt xz;p rintf("===========================\n");p rintf("1、按学号查询\n");p rintf("2、按姓名查询\n");p rintf("===========================\n");p rintf(" 请选择: ");p=head->next;//p为头节点的下一节点s canf("%d",&xz);i f (xz==1){printf("请输入要查找学生的学号:");scanf("%s",num);while(p && strcmp(p->data.num,num)!=0) //循环匹配输入信息是否与当前结点一致,若不一致就转入下一结点进行匹配p=p->next;}e lse if (xz==2){printf("请输入要查找学生的姓名:");T YPEDEF DataType—char,int;{元素类型}LinkList—head;{指针类型}ListNode—node;{结点类型}data:DataType;next:*node;END;ViSitProc—PROCEDURE(p:LinkType);{访问结点的过程类型}int menu_select();LinkList createList(void);void printList(LinkList head);int insertNode(LinkList head,ListNode *p,int i);ListNode *findList(LinkList head);void delNode(LinkList head);void changeNode(LinkList head);LinkList createList(void){L istNode *p,*rear; //结点指针c har flag; //判断是否继续输入的标志h ead=(ListNode *)malloc(sizeof(ListNode));//头节点指针开辟内存r ear=head; //开始头与尾相同w hile(flag!='n'&&flag!='N'){p=(ListNode *)malloc(sizeof(ListNode)); //结点指针开辟空间printf("\n学号(11)姓名(8)性别成绩\n");scanf("%s%s%s%d",p->data.num,p->,p->data.gender,&p->data.score);rear->next = p;//让尾结点指向当前结点的下一结点,并且该节点赋值为p结点rear = rear->next; //尾结点指针指向下一结点printf("按n或N退出,按其他键继续输入\n");getchar();//对标志赋值判断是否继续scanf("%c",&flag);}r ear->next=NULL;//让尾结点的下一结点为空来结束链表r eturn head;//返回头指针}int insertNode(LinkList head,ListNode *p,int i){L istNode *p1;i nt j=1;p1=head;i f(p1->next==NULL)//判断如果为空表,则插入作为第一个结点*//{if(i==0){p1->next=p;//让头节点的指向下一节点,且该结点为p结点p->next=NULL; //p结点的下一结点为空来结束链表}else return -1; //如果在空表情况下输入大于0位置,则返回-1。