收藏 分销(赏)

c语言课程设计—ktv点歌系统.doc

上传人:Fis****915 文档编号:551501 上传时间:2023-12-06 格式:DOC 页数:16 大小:140.50KB
下载 相关 举报
c语言课程设计—ktv点歌系统.doc_第1页
第1页 / 共16页
c语言课程设计—ktv点歌系统.doc_第2页
第2页 / 共16页
c语言课程设计—ktv点歌系统.doc_第3页
第3页 / 共16页
c语言课程设计—ktv点歌系统.doc_第4页
第4页 / 共16页
c语言课程设计—ktv点歌系统.doc_第5页
第5页 / 共16页
点击查看更多>>
资源描述

1、 沈 阳 航 空 航 天 大 学 课程设计 学 号 2010040701020 班 级 04070101 姓 名 指导教师 2011 年 9 月 28 日沈阳航空航天大学课程设计任务书学院:自动化学院 专业:测控技术与仪器 班级:04070101学号:2010040701020 题目:KTV点歌系统模拟(2)一、课程设计时间20112012第1学期第4周,共计1周,20学时。二、课程设计内容请你模范ktv点歌系统,用C语言编写软件完成以下任务:1.读取功能:从song.txt 文件中读取歌曲的信息;2.查看功能:允许用户浏览所用的歌曲,查看某个歌手演唱的所用歌曲;3.删除功能:删除歌曲。三、课

2、程设计要求1.程序质量:l 贯彻结构化的程序设计思想。l 用户界面友好,功能明确,操作方便。l 用户界面中的菜单至少应包括:“读取”、“查看”、“删除”、“退出”4项。l 代码应适当缩进,并给出必要的注释,以增强程序的可读性。 2.课程设计说明书:课程结束后,上交课程设计说明书和源程序。课程设计说明书的格式和内容参见提供的模板。四、指导教师和学生签字指导教师:_ 学生签名:_五、成绩六、教师评语沈阳航空航天大学设计用纸目录一、需求分析1二、设计分析2三、主要界面截图5四、技术要点7五、个人总结8六、参考文献8七、源程序813一、 需求分析根据任务书给定的“课程设计内容”和“课程设计要求”作如下

3、的需求分析。该系统是一个常用的ktv点歌系统,可以让用户根据自己的喜好进行添加、查看、删除等操作。系统应该具有便捷、稳定、功能齐全的特点。1. 便捷性分析系统管理的歌曲涉及到歌曲的各种信息,数据量较大且是一种基础性数据,能够为用户提供许多快捷操作,且操作方便。2. 稳定性分析该系统比较稳定,也比较人性化,只要是用户的合理操作,系统都应给出合理正确的回应,而不是出现令用户感到意外的系统错误或系统崩溃。3. 主要功能分析(1)歌曲的添加:允许用户输入添加歌曲的数量、歌曲名、歌手名、专辑名、歌曲流派。同时,系统会自动把添加歌曲信息保存下来。用户由于疏忽录入的非法数据,能够及时提示并更正。(2)歌曲的

4、查看:用户可以根据自己的需求,输入歌曲名、歌手名、专辑名、歌曲流派中的一项或几项其查看自己想要的歌曲。(3)歌曲的删除:用户在查看歌曲之后,可以根据自己的喜好,删除系统原有的歌曲。用户只需输入歌曲名就可以删除歌曲。删除之后系统自动更新歌曲库。二、设计分析 主要有5个功能模块,每个模块对应一个C语言自定义函数。这些函数原型及其功能简述如下:1、程序总体结构图图1程序总体结构图2、主要功能模块框图(1)读取歌曲函数choice图2读取流程图(2)添加歌曲函数add 图3 添加流程图(3)删除歌曲函数dele 图4删除流程图三、主要界面截图图1 程序主界面图2 数据修改界面四、技术要点1、结构体的应

5、用用结构体来定义描述歌曲编号、歌曲名、歌手名、专辑名、歌曲流派。具体的定义如下:struct song_infoint songnum;char songname15;char songername15;char ablumname15;char type10; 所定义的结构体主要用于定义数组。2、文件操作包括了文件的写入和读取两个方面。文件的写入操作,用于保存录入的歌曲的有关数据,也用于保存所修改的数据。3、多分支选择结构在主函数中使用switch语句,利用自定义函数,实现查看、添加、删除歌曲的功能。五、个人总结 刚开始做的时候,我基本上摸不找头脑,不知道从何处下手。后来,我通过查资料和请教

6、老师,慢慢地学会许多,开始自己做。虽然这期间,我遇到了很多很多的困难,但我收获很多。这次课程设计使我对C语言有了更深的理解,使我知道原来日常生活中的许多系统都是以C语言为基础的,C语言在生产生活应用十分广泛。同时他也锻炼我的逻辑思维能力,提高我解决实际问题的能力。六、参考文献1 谭浩强C程序设计北京:清华大学出版社,2005七、源程序#include#include#include#include#define N 30int i,j,k;FILE *fp;struct song_infoint songnum;char songname15;char songername15;char ab

7、lumname15;char type10;typedef struct song_info SINFO;SINFO *pso;void choice(SINFO *pso)char a15;int q,t;FILE *fp;printf(请输入要查看歌手的名字:); scanf(%s,a); fp=fopen(d:song.txt,rt); if(fp=NULL)printf(the file :song.txt not found!);exit(-1);for(k=0;(!feof(fp);k+)fread(&psok,sizeof(SINFO),1,fp);fclose(fp);t=0;

8、 for(q=0;qk;q+)if(!strcmp(a,psoq.songername)if(t=0)printf(该歌手有以下歌曲:n);t+;printf(%sn,psoq.songname);if(t=0) printf(本系统还无该歌手歌曲,请增添!n);fclose(fp);void add(SINFO *pso)FILE *fp; fp=fopen(d:song.txt,a+);printf(请你输入要增添歌曲的数量:);scanf(%d,&j);fflush(stdin);for(i=0;ij;i+)printf(这是要增添的第%d首歌的信息:n,i+1);printf(歌曲编号

9、是:);scanf(%d,&psoi.songnum);fflush(stdin);printf(歌曲名字是:);gets(psoi.songname);fflush(stdin);printf(歌手名字是:);gets(psoi.songername);fflush(stdin);printf(专辑的名字是:);gets(psoi.ablumname);fflush(stdin);printf(歌曲流派是:);gets(psoi.type);fflush(stdin);system(cls);fwrite(&psoi,sizeof(SINFO),1,fp);fclose(fp);printf

10、(歌曲增添成功!n);void show(SINFO *pso)FILE *fp;fp=fopen(d:song.txt,rt); if(fp=NULL)printf(the file :song.txt not found!);exit(-1);printf(所有歌曲信息如下:n);for(k=0;!feof(fp);k+) fread(&psok,sizeof(SINFO),1,fp);fclose(fp);printf(%s%15s%20s%15s%15s,歌曲编号,歌名,歌手,专辑,歌曲流派);printf(n);for(i=0;ik-1;i+)printf(%03d%20s%20s%

11、15s%15s,psoi.songnum,psoi.songname,psoi.songername,psoi.ablumname,psoi.type);printf(n);void dele(SINFO *pso)char a15;int q;FILE *fp;printf(请输入要删除歌曲的名字:); scanf(%s,a); fp=fopen(d:song.txt,rt); if(fp=NULL)printf(the file :song.txt not found!);exit(-1);for(k=0;(!feof(fp);k+)fread(&psok,sizeof(SINFO),1,

12、fp);fclose(fp);for(q=0;qk;q+)if(!strcmp(a,psoq.songname)memset(&psoq,0,sizeof(SINFO);fp=fopen(d:song.txt,w+);for(k=0;kq;k+)fwrite(&psok,sizeof(SINFO),1,fp);fclose(fp);printf(删除信息成功!n);void out()char a;printf(确认退出系统?(y/n);scanf(%c,&a);if(y=a)exit(0);main()SINFO *pso;loop:printf( 欢迎使用KTV选歌系统 n);printf

13、( 1.选歌 n);printf( 2.新增歌曲 n);printf( 3.查看歌曲信息 n);printf( 4.删除歌曲 n);printf( 5.退出 n);printf(请选择功能: );scanf(%d,&i);fflush(stdin);pso=(SINFO*)malloc(N*sizeof(SINFO); memset(pso,0,(N*sizeof(SINFO);system(cls);switch(i)case 1:choice(pso);goto loop;break;case 2:add(pso);goto loop;break;case 3:show(pso);goto loop;break;case 4:dele(pso);goto loop;break;case 5:out();goto loop;break;default:printf(输入错误!请重新选择!n);goto loop;

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 教育专区 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服