《C语言程序设计课程设计》题目-软件工程2班

上传人:z**** 文档编号:168825929 上传时间:2022-11-12 格式:DOCX 页数:12 大小:35.90KB
收藏 版权申诉 举报 下载
《C语言程序设计课程设计》题目-软件工程2班_第1页
第1页 / 共12页
《C语言程序设计课程设计》题目-软件工程2班_第2页
第2页 / 共12页
《C语言程序设计课程设计》题目-软件工程2班_第3页
第3页 / 共12页
资源描述:

《《C语言程序设计课程设计》题目-软件工程2班》由会员分享,可在线阅读,更多相关《《C语言程序设计课程设计》题目-软件工程2班(12页珍藏版)》请在装配图网上搜索。

1、1 一元稀疏多项式的运算问题描述:设有两个带头指针的单链表表示两个一元稀疏多项式A、B,实现两 个一元稀疏多项式的处理。实现要求: 输入并建立多项式; 输出多项式,输出形式为整数序列:n,C, e1,c2,e2cn,en,其中n是多项式的项数,cj ei分别为第i项的系数和指数。序列按指数降序排列; 多项式A和B相加,建立多项式A+B,输出相加的多项式; 多项式A和B相减,建立多项式A-B,输出相减的多项式; 多项式A和B相乘,建立多项式AxB,输出相乘的多项式; 设计一个菜单,至少具有上述操作要求的基本功能。测试数据:(1) (2x+5x8-3.1x11)+(7-5x8+11x9)(2) (

2、6x-3-x+4.4x2-1.2x9)-(-6x-3+5.4x2+7.8x15)(3) (x+x2+x3)+0(4) (x+x3)-(-x-x-3)2 成绩排序假设某年级有4个班,每班有45名同学。本学期有5门课程考试,每门课 程成绩是百分制。假定每个同学的成绩记录包含:学号、姓名各门课程的成绩 共 7 项,其中学号是一个 10 位的字符串,每个学生都有唯一的学号,并且这 4 个班的成绩分别放在 4个数组中,完成以下操作要求: 编写一个成绩生成函数,使用随机数方法,利用随机函数生成学生的 各门课程的成绩(每门课程的成绩都是OslOO之间的整数),通过调用该函数 生成全部学生的成绩; 编写一个平

3、均成绩计算函数,计算每个同学的平均成绩并保存在成绩数组中; 用冒泡排序法对 4 个班的成绩按每个同学的平均成绩的以非递增方式 进行班内排序; 用选择排序法对 4 个班的成绩按每个同学的平均成绩的以非递增方式 进行班内排序; 对已按平均成绩排好序的 4 个班的同学的构造一个所有按平均成绩的 以非递增方式排列的新的单链表; 设计一个菜单,至少具有上述操作要求的基本功能。(本题由2人完成)3 迷宫问题问题描述:以一个mxn的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍。设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路, 或得出没有通路的结论。实现要求: 实现一个以链表作存储结构的栈类型

4、,然后编写一个求解迷宫的非递归程序。求得的通路以三元组(i,j,d)的形式输出,其中:(i,j)指示迷宫中 的一个坐标,d表示走到下一坐标的方向。 编写递归形式的算法,求得迷宫中所有可能的通路; 以方阵形式输出迷宫及其通路。测试数据 迷宫的测试数据如下:左上角(1,1)为入口,右下角(8,9)为出口。1 2 3 4 5 6 7 8001000100010001000001101011100100001000001000101011110011100010111000000实现提示:计算机解迷宫通常用的是“穷举求解”方法,即从入口出发,顺着某一个方向 进行探索,若能走通,则继续往前进;否则沿着原

5、路退回,换一个方向继续探 索,直至出口位置,求得一条通路。假如所有可能的通路都探索到而未能到达 出口,则所设定的迷宫没有通路。 可以二维数组存储迷宫数据,通常设定入口点的下标为( 1,1),出口点的下 标为(m,n)。为处理方便起见,可在迷宫的四周加一圈障碍。对于迷宫中任一 位置,均可约定有东、南、西、北四个方向可通。4 栈及其操作问题描述:栈(Stack):是限制在表的一端进行插入和删除操作的线性表。又称为后进先 出 LIFO (Last In First Out)或先进后出 FILO (First In Last Out)线性表。栈顶(Top):允许进行插入、删除操作的一端,又称为表尾。用

6、栈顶指针(top) 来指示栈顶元素。栈底(Bottom):是固定端,又称为表头。空栈:当表中没有 元素时称为空栈。设栈S=(a1,a2,.an),则al称为栈底元素,an为栈顶元素。栈中元素按 al,a2,.an的次序进栈,退栈的第一个元素应为栈顶元素an。即栈的修改是 按后进先出的原则进行的。栈的链式存储结构称为链栈,是运算受限的单链表。其插入和删除操作只 能在表头位置上进行。链栈的基本形式如下:A空链栈非空链栈实现要求: 链栈基本操作的实现:栈的初始化,生成一个空栈;压栈,即元素进 栈;弹栈,即元素出栈; 十进制整数 N 向其它进制数 d( 二、八、十六 ) 的转换是计算机实现计算 的基本

7、问题。转换法则:该转换法则对应于一个简单算法原理: n=(n div d)*d+n mod d 其中:div为整除运算,mod为求余运算 在文字处理软件或编译程序设计时,常常需要检查一个字符串或一个表 达式中的括号是否相匹配?匹配思想:从左至右扫描一个字符串(或表达式),则每个右括号将与最近遇到的那个左括号相匹配。则可以在从左至右扫描过程中把所遇到的左括号存放到堆栈中。每当遇到一个右括号时,就将它与栈顶的左括号(如果存在)相 匹配,同时从栈顶删除该左括号。算法思想:设置一个栈,当读到左括号时,左括号进栈。当读到右括号时, 则从栈中弹出一个元素,与读到的左括号进行匹配,若匹配成功,继续读入; 否

8、则匹配失败,返回 FLASE。5 航班信息管理问题描述:飞机航班系统的数据包括两部分: 航班信息:航班号、最大载客数、起飞地点、起飞时间、降落地点、降 落时间,单价; 乘客信息:航班号、身份证号码、姓名、性别、出生年月、座位号。乘客订票的主要方式是:乘客提出航班号、起飞地点、起飞时间、降落地 点、订票数等订票要求,根据事先保存的航班数据决定乘客能否订票?只有全 部满足了乘客的订票要求并且所订航班有足够的未订座位之后才能完成订票处 理,并且修改该航班的未订座位数(每个航班的未订座位数的初始值就是该航 班的最大载客数);否则,订票失败,并且给出不能订票的原因。要求将航班数据保存在数据文件中,在处理

9、时按航班的起飞地点建立不同 的链表。功能要求: 增加航班记录。将新的航班记录增加到原有的航班数据文件中。在进行 处理时必须检查所要增加的航班记录是否存在,如果已经存在,应给出提示信 息后停止增加; 航班取消。如果某次航班的乘客数太少(已订票的少于本次航班最大载 客数的10%),将取消该航班,但该航班的记录仍然保存在原有的航班数据文件 中; 航班查询。应该有以下几种基本的查询方式:按航班号、按起飞地点和 起飞时间、按降落地点,按起飞地点和降落地点; 航班订票。按上述问题描述中的乘客订票方式完成航班订票处理。 设计一个菜单,至少具有上述操作要求的基本功能。6 运动会管理系统问题描述:校际运动会管理

10、系统。设有n个学校参加校际运动会,共有男子竞赛项目 数m,女子竞赛项目数w。每个学校可以参加所有竞赛项目,也可以只参加部分 竞赛项目,每个学校对每个项目的参赛运动员不能超过4人,每个运动员最多 只能参加3项单项比赛,团体赛不受限制。各项目名次取法有如下几种:用户自定义:(各名次权值由用户指定) 参赛人数超过6人,取前5名:第1名得分 7,第2名得分 5,第3名 得分3,第4名得分2,第5名得分 1; 参赛人数不超过6人,取前3名:第1名得分5,第2名得分3,第3 名得分2; 团体项目的名次取法和上面相同,但分数加倍。功能要求: 运动员报名登记,以学校为单位进行运动员报名登记,登记的限制要求 按

11、问题描述的要求; 参赛信息查询,查看参赛学校信息和比赛项目信息; 竞赛检录,每项比赛开始前完成参赛运动员的检录; 竞赛成绩登记,填写比赛名次,然后根据竞赛检录的运动员人数和上述的记分方式自动完成各学校的成绩登记并实时生成各学校的团体总分; 比赛成绩查询,可以按竞赛项目、参赛学校、参赛运动员查看比赛成绩; 竞赛成绩排序,以学校为单位,按总成绩的高低,分别排序输出每个学 校的总成绩、男子总成绩、女子总成绩; 设计一个菜单,至少具有上述操作要求的基本功能。(本题由 2 人完成)7 集合运算问题描述:设有两个用单链表表示的集合A、B,其元素类型是int且以非递减方式存 储,其头结点分别为a、b。要求下

12、面各问题中的结果集合同样以非递减方式存 储,结果集合不影响原集合。实现要求: 编写集合元素测试函数IN_SET,如果元素已经在集合中返回0,否则 返回 1; 编写集合元素输入并插入到单链表中的函数INSERT_SET,保证所输入 的集合中的元素是唯一且以非递减方式存储在单链表中; 编写集合元素输出函数,对建立的集合链表按非递增方式输出; 编写求集合A、B的交C=AGB的函数,并输出集合C的元素; 编写求集合A、B的并D=AUB的函数,并输出集合D的元素; 求集合A与B的对称差E=(A-B) U (B-A)的函数,并输出集合D的元素;设计一个菜单,具有输入集合元素、求集合A、B的交C、求集合A、

13、B的并D、求集合A与B的对称差E、退出等基本的功能。测试数据:由读者自定,但集合 A、 B 的元素个数不得少于 16 个。8 矩阵的操作实现要求: 编写矩阵输入函数INPUT_MAT,通过该函数完成矩阵的输入并返回保 存矩阵的三元组(不能使用全局变量);(2)编写矩阵输出函数OUTPUT_MAT,通过该函数完成矩阵的输出,输出的形式是标准的矩阵形式(即二维数组的形式); 求矩阵的转置,矩阵的转置A =(aji)nxm,转置前输出原矩阵,转置后 输出转置矩阵; 求矩阵A、B的和。矩阵A和B能够相加的条件是:m=p, n=q;矩阵 A和B如果不能相加,请给出提示信息;若能够相加,则求和矩阵C并输出

14、C; C=A+B=(c.),其中 c. a.+b.ij mxnij= ij ij 求矩阵A、B的差。矩阵A和B能够相减的条件是:m=p,n=q;矩阵 A和B如果不能相减,请给出提示信息;若能够相减,则求差矩阵C并输出C; C=A-B=(c.),其中 c. a.-b.ij mxnij= ij ij 求矩阵A、B的积。矩阵A和B能够相乘的条件是:p=n;矩阵A和B 如果不能相乘,请给出提示信息;若能够相乘,则求积矩阵 D 并输出 D;D=AXB=(d.),其中 d.工a xb,k=l,2,nij mx qij= ik kj 设计一个菜单,具有求矩阵的转置、求矩阵的和、求矩阵的积、退出等 基本的功能

15、。在求矩阵的和或求矩阵的积时要求能够先提示输入两个矩阵的, 然后再进行相应的操作。9 数据汇总问题描述:在数据处理中经常需要对大量数据进行汇总,将相同关键字记录的某些数 据项的值叠加起来,生成一个分类汇总表。假设某超级市场销售有m种商品(假设商品的编号为1,2, 3, m), 有n台前台收款机(假设收款机的编号为1, 2, 3, , n)进行收款,以记录的形式提供给计算机,每个记录表示某台收款机的一种商品一次交易的数量 和销售额。记录由 4 个域组成:收款机编号、商品编号、销售数量、销售金额。 构造一个结构体类型,每次销售数据以一个结构体变量保存在一个数据文件中。实现要求: 编写实现将数据记录

16、插入到数据文件的最后的函数; 编写以收款机为单位的数据分类处理函数。构造 n 个单链表,每个链 表保存一台收款机的销售记录,这 n 个单链表的头指针存放在一个指针数组中, 通过数组的下标就可以知道是哪台收款机。读取数据文件的记录,将所有的销 售记录(数据文件中的全部记录)分解插入到 n 个单链表; 编写以商品为单位的数据分类处理函数。构造 m 个单链表,每个链表 保存一种商品的销售记录,这 m 个单链表的头指针存放在一个指针数组中,通 过数组的下标就可以知道是哪种商品。读取数据文件的记录,将所有的销售记 录(数据文件中的全部记录)分解插入到 m 个单链表; 统计每台收款机的销售总额; 以收款机

17、为单位,将所有收款机按销售总额的非递减顺序构造一个单 链表并输出; 以商品为单位,统计每种商品的销售总额; 以商品为单位,将所有销售的商品按销售总额的非递减顺序构造一个 单链表并输出; 设计一个菜单,具有上述要求的所有功能、退出系统等最基本的功能。10 joseph 环题目之一:问题描述:编号是1, 2,n的n个人按照顺时针方向围坐一圈,一开始任选一 个正整数作为报数上限(开始)值m(mVn),从第s(sVn)个人开始沿顺时针方 向顺序报数,报到m时停止报数,报m的人出列,然后在从他在顺时针方向的 下一个人开始重新从 1 报数,如此下去,直到所有人全部出列为止。设计一个 程序来求出出列顺序。实

18、现要求: 利用单向循环链表存储结构模拟此过程,按照出列的顺序输出各个人的 编号。输入数据:建立输入处理输入数据,输入m、n、s的初值和每个人的编号, 建立单循环链表。输出形式:建立一个输出函数,将正确的序列输出。 利用顺序表存储结构模拟此过程,按照出列的顺序输出各个人的编号。 输入数据:建立输入处理输入数据,输入 m、n、s 的初值和每个人的编号, 建立单循环链表。输出形式:建立一个输出函数,将正确的序列输出。测试数据:m的初值为20,n=7,7个人的密码依次为3,1, 7, 2, 4, 7, 4,首先m=6, 则正确的输出是什么?题目之二:问题描述:编号是1, 2,n的n个人按照顺时针方向围

19、坐一圈,一开始任选一 个正整数作为报数上限(开始)值m(mVn),从第s(sVn)个人开始沿逆时针方 向顺序报数,报到m时停止报数,报m的人出列,然后在从他在逆时针方向的 下一个人开始重新从 1 报数,如此下去,直到所有人全部出列为止。设计一个 程序来求出出列顺序。实现要求: 利用单向循环链表存储结构模拟此过程,按照出列的顺序输出各个人的 编号。输入数据:建立输入处理输入数据,输入 m、n、s 的初值和每个人的编号, 建立单循环链表。输出形式:建立一个输出函数,将正确的序列输出。 利用顺序表存储结构模拟此过程,按照出列的顺序输出各个人的编号。输入数据:建立输入处理输入数据,输入m、n、s的初值

20、和每个人的编号, 建立单循环链表。输出形式:建立一个输出函数,将正确的序列输出。测试数据:m的初值为31, n=7,7个人的密码依次为3,1, 7, 2, 4, 7, 4,首先m=6, 则正确的输出是什么?11 背包问题的求解题目之一:问题描述:假设有一个能装入总体积为T的背包和n件体积分别为W , w2 , wn的物品,能否从 n 件物品中挑选若干件恰好装满背包,即使 w1 +w2 + + wn=T, 要求找出所有满足上述条件的解。例如:当T=10,各件物品的体积1, 8, 4, 3, 5, 2时,可找到下列4组解:(1, 4, 3, 2)(1, 4, 5)(8, 2)(3, 5, 2)。问

21、题提示:可利用回溯法的设计思想来解决背包问题。首先将物品排成一列,然后顺 序选取物品装入背包,假设已选取了前 i 件物品之后背包还没有装满,则继续 选取第i+1件物品,若该件物品太大不能装入,则弃之而继续选取下一件,直 至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说 明刚刚装入背包的那件物品不合适,应将它取出弃之一边,继续再从它 之后的物品中选取,如此重复,直至求得满足条件的解,或者无解。题目之二:问题描述:假设有n件物品,这些物品的重量分别是W1 , W2,Wn,物品的价值分 别是VI, V2,,Vn。求从这n件物品中选取一部分物品的方案,使得所选 中的物品的总重量不超

22、过限定的重量W (WWi, i=l,2,n),但所选中的物品 价值之和为最大。问题提示:利用递归寻找物品的选择方案。假设前面已有了多种选择的方案,并保留 了其中总价值最大的方案于数组option中,该方案的总价值保存于变量 max_value中。当前正在考察新方案,其物品选择情况保存于数组eop中。假 设当前方案已考虑了 i-1件物品,现在要考虑第i件物品:当前方案已包含的物 品的重量之和为tw;因此,若其余物品都选择是可能的话,本方案所能达到的 总价值的期望值设为tv。引入tv是当一旦当前方案的总价值的期望值也小于前 面方案的总价值max_value时,继续考察当前方案已无意义,应终止当前方

23、案而 去考察下一个方案。第 i 件物品的选择有两种可能: 物品i被选择。这种可能性仅当包含它不会超过方案总重量的限制才是 可行的。选中之后继续递归去考虑其余物品的选择; 物品i不被选择。这种可能性仅当不包含物品i也有可能找到价值更大 的方案的情况。12 学生成绩管理问题描述: 设学生信息包括:学号、姓名、学期、每门课程的成绩(每学期的课程门数 是不一样的) ,对学生的成绩信息进行管理。实现要求: 实现:学生信息的录入;修改;删除和查询,按学期、学号、成绩不及格 等查询。 输入学生的成绩信息,包含学号、姓名、性别等基本信息和各课成绩 显示全部学生各科成绩信息; 对各科成绩统计分析(总分、平均分、最高分、最低分、及格率等); 统计各科各分数段人数; 按学号或姓名查找并显示某个学生的各科成绩; 按课程成绩或总分由高到低排序显示; 更新某个学生的基本信息或课程成绩; 设计一个菜单,具有上述规定的操作要求、退出系统等最基本的功能。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!