第一篇:一份c语言的课程设计体会
体会
通过这次C语言的课程设计,我明白了很多也知道了很多,更收获了很多。在课程设计的过程中出现过困难,三周的课程设计已经结束了。回想学习C语言的过程中,既有快乐又有烦恼,回顾这次课程设计,至今我仍感慨颇多,的确,自从拿到题目到完成整个编程,从理论到实践,在整整一个星期的日子里,可以学到很多很多的东西,同时不仅可以巩固了以前所学过的知识,而且学到了很多在书本上所没有学到过的知识。通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论和知识是远远不够的,只有把所学的理论知识与实际相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考能力。在设计的过程中遇到的问题,这毕竟独立做的,难免会遇到各种各样的问题,同时在设计的过程中发现自己的不足之处,对以前所学的知识理解得不够深刻,掌握得不够牢固,比如说结构体……通过这次课程设计之后,一定把以前所学过的知识从新温故。这次课设终于顺利完成了,在设计中遇到了很多编程问题
做完这个课程设计,我们的自信一下子提高了,我们也会写程序了;尽管对于有些人这种程序会很简单,可对于我们C语言初学者来说,已经很不容易了。这次体验为以后的学习计算机的我们增强了信心。享受劳动成果的滋味实在美妙啊!
很感谢这次的课程设计,它使我更加地体会到多看专业书的重要性,只有掌握了一定量的专业知识才能得心应手地解决诸多问题;另外,在做任何事倒要有耐心,不要一遇到困难就退缩;在学习和工作中要时刻谨记“团结”二字,它好比通向成功的铺路石,不可或缺。
人生的道路是曲折的,但正是因为曲折人生才光彩夺目,在人生的道路上,总遇到重重困难,但正是因为困难我们才变得更坚强。今后的路还很长,面对困难,让我们用行动去俘虏它吧!
第二篇:C语言课程设计
#include
int num1;
char name1[20];
int score;
int nelepeo;//课程已选人数
int Melepeo;//课程人数上限
struct couse * next;};
int student();
//学生登陆 int teacher();
//教师登陆 struct student//学生信息结构体 {
int num2;
char name2[20];
int nelenum[50];//已选课程编号
int nelen;//已选课程数量
struct student * next;};
void Ms(){
for(kk1=0;kk1<1100;kk1++)
for(kk2=0;kk2<1200;kk2++)
for(kk3=0;kk3<1200;kk3++);} void keyboardc()//录入课程子函数(从键盘录入){ void intoc();struct couse *p1,*p2;N1=0;p1=p2=(struct couse*)malloc(sizeof(struct couse));printf(“n课程编号:”);fflush(stdin);scanf(“%d”,&p1->num1);printf(“n课程名称:”);scanf(“%s”,p1->name1);printf(“n学分:”);scanf(“%d”,&p1->score);printf(“n课程人数上限:”);scanf(“%d” ,&p1->Melepeo);printf(“ntttt输入成功!”);p1->nelepeo=0;head1=NULL;while(p1->num1!=0){
N1=N1+1;
if(N1==1)head1=p1;
else p2->next=p1;
p2=p1;
p1=(struct couse *)malloc(sizeof(struct couse));
printf(“n-----------------------------”);
printf(“n课程编号:(输入0结束)”);scanf(“%d”,&p1->num1);printf(“n课程名称:”);scanf(“%s”,p1->name1);printf(“n学分:”);scanf(“%d”,&p1->score);printf(“n课程人数上限:”);scanf(“%d” ,&p1->Melepeo);
p1->nelepeo=0;
printf(“ntttt输入成功!”);} p2->next=NULL;intoc();}
void filec()//录入键盘子函数(从文件录入){ void intoc();
FILE * fp;
char filepath[20];
struct couse *p1,*p2;
N1=0;
printf(“输入要读入的文件路径:”);
getchar();
gets(filepath);
if((fp=fopen(filepath,“r”))==NULL)
{
printf(“找不到%s文件!n”,filepath);
exit(0);
}
p1=p2=(struct couse*)malloc(sizeof(struct couse));
fscanf(fp,“%d%s%d%d%d”,&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo);
head1=NULL;
while(!feof(fp))
{
N1=N1+1;
if(N1==1)head1=p1;
else p2->next=p1;
p2=p1;
p1=(struct couse *)malloc(sizeof(struct couse));
fscanf(fp,“%d%s%d%d%d”,&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo);
}
p2->next=NULL;
intoc();}
void inputc()//录入课程主函数 {
int i;
printf(“ttt录入课程信息n”);
printf(“n1.从键盘录入n”);
printf(“2.从文件录入n”);
printf(“3.返回主菜单n”);
printf(“请选择(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):keyboardc();break;
case(2):filec();break;
case(3):system(“cls”);return;break;
//return
} }
void insertc(struct couse *incouse)//课程管理子函数(增加课程){ void intoc();
struct couse *p0,*p1,*p2;
p1=head1;
p0=incouse;
if(head1==NULL)
{
head1=p0;
p0->next=NULL;
}
else
{
while((p0->num1 > p1->num1)&&(p1->next!=NULL))
{
p2=p1;
p1=p1->next;
}
if(p0->num1 <= p1->num1)
{
if(head1==p1)head1=p0;
else p2->next=p0;
p0->next=p1;
}
else
{
p1->next=p0;
p0->next=NULL;
}
}
N1=N1+1;
intoc();}
void delc(int num1)//课程管理子函数(删除课程){ void intoc();
struct couse *p1,*p2;
if(head1==NULL)
{
printf(“n没有课程,无法删除!n”);
goto end;
}
p1=head1;
while(num1!=p1->num1 && p1->next!=NULL)
{
p2=p1;
p1=p1->next;
}
if(num1==p1->num1)
{
if(p1==head1)head1=p1->next;
else p2->next=p1->next;
printf(“已删除该编号课程!n”);
N1=N1-1;
}
else printf(“无该编号的课程!n”);
end:;
intoc();}
void managementc()//课程管理主函数 {
struct couse * incouse;
struct couse *p1;
int i,num1;
printf(“ttt课程管理n”);
printf(“1.新增课程n”);
printf(“2.删除课程n”);
printf(“3.返回主菜单n”);
printf(“请选择(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):
{
incouse=(struct couse *)malloc(sizeof(struct couse));
printf(“n课程编号:”);
fflush(stdin);
scanf(“%d”,&p1->num1);
printf(“n课程名称:”);
scanf(“%s”,p1->name1);
printf(“n学分:”);
scanf(“%d”,&p1->score);
printf(“n课程人数上限:”);
scanf(“%d” ,&p1->Melepeo);
printf(“ntttt输入成功!”);
incouse->nelepeo=0;
insertc(incouse);
break;
}
case(2):
{
printf(“请输入要删除课程的编号:n”);
scanf(“%d”,&num1);
delc(num1);
break;
}
case(3):system(“cls”);return;break;
} }
void keyboards()//录入学生信息子函数(从键盘录入){
void intos();
int i;
struct student *p1,*p2;
N2=0;
p1=p2=(struct student *)malloc(sizeof(struct student));
printf(“n学生学号:”);
scanf(“%d”,&p1->num2);
printf(“n学生姓名:”);
scanf(“%s”,p1->name2);
p1->nelen=0;
for(i=0;i<50;i++)p1->nelenum[i]=0;
head3=NULL;
while(p1->num2!=0)
{
N2=N2+1;
if(N2==1)head3=p1;
else p2->next=p1;
p2=p1;
p1=(struct student *)malloc(sizeof(struct student));
//return
printf(“n学生学号:(输入0结束!)”);
scanf(“%d”,&p1->num2);
printf(“n学生姓名:”);
scanf(“%s”,p1->name2);
p1->nelen=0;
for(i=0;i<50;i++)p1->nelenum[i]=0;
}
p2->next=NULL;
intos();return;} void files()//录入学生信息子函数(从文件录入){
int i=0;
FILE * fp;
char filepath[20];
struct student *p1,*p2;
N2=0;
printf(“输入要读入的文件路径:”);
getchar();
gets(filepath);
if((fp=fopen(filepath,“r”))==NULL)
{
printf(“找不到%s文件!n”,filepath);
exit(0);
}
p1=p2=(struct student*)malloc(sizeof(struct student));
fread(p1,sizeof(struct student),1,fp);
head3=NULL;
while(!feof(fp))
{
i=0;
N2=N2+1;
if(N2==1)head3=p1;
else p2->next=p1;
p2=p1;
p1=(struct student *)malloc(sizeof(struct student));
fread(p1,sizeof(struct student),1,fp);
}
p2->next=NULL;}
void inputs()//录入学生信息主函数 {
int i;
printf(“nttt录入学生信息n”);
printf(“n1.从键盘录入n”);
printf(“2.从文件录入n”);
printf(“3.返回主菜单n”);
printf(“请选择(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):keyboards();break;
case(2):files();break;
case(3):system(“cls”);return;break;
}
return 0;}
void inserts(struct student * incouse)//学生信息管理子函数(填加学生信息){ void intos();
struct student *p0,*p1,*p2;
p1=head3;
p0=incouse;
if(head3==NULL)
{
head3=p0;
p0->next=NULL;
}
else
{
while((p0->num2 > p1->num2)&&(p1->next!=NULL))
{
p2=p1;
p1=p1->next;
}
if(p0->num2 <= p1->num2)
{
if(head3==p1)head3=p0;
else p2->next=p0;
p0->next=p1;
}
else
{
//return
p1->next=p0;
p0->next=NULL;
}
}
N2=N2+1;
intos();}
void dels(int num2)//学生信息管理子函数(删除学生信息){ void intos();
struct student *p1,*p2;
if(head3==NULL)
{
printf(“n没有该学生信息,无法删除!n”);
goto end;
}
p1=head3;
while(num2!=p1->num2 && p1->next!=NULL)
{
p2=p1;
p1=p1->next;
}
if(num2==p1->num2)
{
if(p1==head3)head3=p1->next;
else p2->next=p1->next;
printf(“已删除该学生信息!n”);
N2=N2-1;
}
else printf(“无该学号的学生!n”);
intos();
end:;}
void managements()//学生信息管理主函数 {
struct student * incouse;
int i,num2;
printf(“ttt学生信息管理n”);
printf(“1.新增学生信息n”);
printf(“2.删除学生信息n”);
printf(“3.返回主菜单n”);
printf(“请选择(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):
{
incouse=(struct student *)malloc(sizeof(struct student));
incouse->nelen=0;
incouse->nelenum[0]=0;
printf(“学生学号t学生姓名n”);
scanf(“%d%s”,&incouse->num2,incouse->name2);
inserts(incouse);
break;
}
case(2):
{
printf(“请输入要删除学生的学号:n”);
scanf(“%d”,&num2);
dels(num2);
break;
}
case(3):system(“cls”);return;break;
//return
} }
void elect(struct student * s)//选课 {
void intos();
struct couse * p;
int num1,i;
printf(“请输入要选课的编号:n”);
scanf(“%d”,&num1);
for(i=0;s->nelenum[i]!=0;i++);
s->nelenum[i]=num1;
(s->nelen)++;
p=head1;
while(p->num1!=num1)p=p->next;
(p->nelepeo)++;
intos();} void cheak()//学生选课子函数(查询可选课程){
char e;
struct couse * c;
struct student * s;
int num2,i,j=0,t=0;
printf(“请输入你的学号:”);
scanf(“%d”,&num2);
s=head3;
while((s->num2!=num2)&&(s->next!=NULL))s=s->next;
if(s->num2!=num2)
{
printf(“不存在你的信息,请进入主菜单录入你的信息!n”);
goto end;
}
c=head1;
printf(“你的可选课程编号:n”);
while(c!=NULL)
{
for(t=0,i=0;s->nelenum[i]!=0;i++)
{
if(c->num1==s->nelenum[i])t=1;
}
if(t==0 &&(c->nelepeo!=c->Melepeo))
{
printf(“%dn”,c->num1);
j++;
}
c=c->next;
}
if(j==0)
{
printf(“你已选完所有课程,无法再多选!n”);
goto end;
}
printf(“选课(y/n)?:n”);
getchar();
e=getchar();
i=0;
while((e=='y')||(e=='Y'))
{
elect(s);
printf(“继续选课(y/n)?:n”);
getchar();
e=getchar();
}
end:;} void back(struct student * p)//退课 {
void intos();
struct couse * p1;
int num1,i,j;
printf(“请输入你要退掉的课程编号:n”);
scanf(“%d”,&num1);
p1=head1;
while(p1->num1!=num1)p1=p1->next;
for(i=0;p->nelenum[i]!=num1;i++);
for(j=i;p->nelenum[j]!=0;j++)p->nelenum[j]=p->nelenum[j+1];
p->nelenum[--j]=0;
(p1->nelepeo)--;
printf(“退课成功!n”);
intos();} void hcheak()//学生选课子函数(查询已选课程){
char c;
struct couse * p0;
struct student * p;
int num2,i,f=0;
printf(“请输入学号:n”);
scanf(“%d”,&num2);
p=head3;
while(p->num2!=num2 && p!=NULL)p=p->next;
if(p==NULL)
{
printf(“不存在你的信息,请回主菜单录入信息:n”);
goto end;
}
printf(“已选课程编号:n”);
if(p->nelenum[0]==0)
{
printf(“你还没选课!n”);
goto end;
}
for(i=0;p->nelenum[i]!=0;i++)
{
printf(“%dn”,p->nelenum[i]);
p0=head1;
while(p0->num1!=p->nelenum[i])p0=p0->next;
f=f+p0->score;
}
printf(“总学分:%dn”,f);
printf(“是否进行退课(y/n)?”);
getchar();
c=getchar();
while((c=='y')||(c=='Y'))
{
back(p);
printf(“继续退课(y/n)?”);
getchar();
c=getchar();
(p->nelen)--;
}
end:;} void elective()//学生选课主函数 {
int i;
printf(“ttt学生选课n”);
printf(“1.查询可选课程n”);
printf(“2.查询已选课程n”);
printf(“3.返回主菜单n”);
printf(“请输入(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):cheak();break;
case(2):hcheak();break;
case(3): system(“cls”);return;break;
// return
} } void listc()//输出课程信息 {
struct couse * p;
p=head1;
printf(“课程编号
课程名称
学分
课程已选人数
课程人数上限n”);
while(p!=NULL)
{
printf(“%-8d%10s%6d%8d%12dn”,p->num1,p->name1,p->score,p->nelepeo,p->Melepeo);
p=p->next;
} }
void lists()//输出学生信息 {
struct student * p;
p=head3;
printf(“学生学号
学生姓名
已选课程数量n”);
while(p!=NULL)
{
printf(“%-4d %10s %6dn”,p->num2,p->name2,p->nelen);
p=p->next;
} } void intoc()//存储课程信息 {
FILE * fp;
struct couse * p;
char filepath[30];
if((fp=fopen(“课程信息.dat”,“a+”))==NULL)
{
printf(“n保存失败!”);
exit(0);
}
p=head1;
while(p!=NULL)
{
fprintf(fp,“%d %s %d %d %dn”,p->num1,p->name1,p->score,p->nelepeo,p->Melepeo);
p=p->next;
}
fclose(fp);
printf(“课程信息已保存成功!n”);} void intos()//存储学生信息 { int i;
FILE * fp;
struct student * p;
char filepath[30];
if((fp=fopen(“学生信息.dat”,“a+”))==NULL)
{
printf(“n保存失败!”);
exit(0);
}
p=head3;
while(p!=NULL)
{
fwrite(p,sizeof(struct student),1,fp);
p=p->next;
}
fclose(fp);
printf(“学生信息已保存成功!n”);
printf(“ntttt选择菜单:”);
printf(“ntttt1.继续添加ntttt2.返回主菜单:”);
printf(“请选择:”);
scanf(“%d”,&i);
switch(i)
{
case 1:inputs();break;
case 2:teacher();break;
default:printf(“n输入有误!n”);} }
void store()//信息主函数 {
int i;
printf(“tt系统信息查看及存储n”);
printf(“1.查看课程信息n”);
printf(“2.查看学生信息n”);
printf(“3.返回主菜单n”);
printf(“请输入(1~3):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):listc();break;
case(2):lists();break;
case(3):system(“cls”);return;break;
} }
int main()//主函数
//retuen
{
int i;
FILE *fp;
printf(“nttt欢迎使用学生选课系统!n”);
printf(“n请选择菜单:”);
printf(“ntttt1.教师登陆ntttt2.学生登陆n”);
printf(“请选择:”);
scanf(“%d”,&i);
switch(i)
{
case 1:teacher();break;
case 2:student();break;
default:printf(“输入有误!”);
} }
int student()
{
int i;
printf(“ntttt1.学生选课n”);
printf(“ntttt2.系统信息查看及存储n”);
printf(“ntttt3.退出系统n”);
printf(“请选择:”);
scanf(“%d”,&i);
switch(i)
{
case 1:
{
system(“cls”);
elective();
break;
}
case 2:
{
system(“cls”);
store();
break;
}
default:printf(“输入有误!”);
}
}
int teacher()
{
FILE *fp;
int i;
printf(“菜单:n”);
printf(“1.录入课程信息n”);
printf(“2.课程管理n”);
printf(“3.录入学生信息n”);
printf(“4.学生信息管理n”);
printf(“5.系统信息查看n”);
printf(“6.退出系统n”);
if((fp=fopen(“课程信息.dat”,“rb”))==NULL)
{
printf(“n打开系统文件失败!
n”);
//fp=fopen(“信息.dat”,“rb”));
// }
// if(feof(fp))
// {
printf(“n还未添加课程信息,请添加课程信息!n”);
inputc();
}
while(!feof(fp))
{
emp1=(struct couse*)malloc(sizeof(struct couse));
if(emp1==NULL)
{
printf(“n分配内存失败!n”);
return;
}
fread(emp1,sizeof(struct couse),1,fp);
if(feof(fp))break;
if(head1==NULL)
{
head1=emp1;
head2=emp1;
}
else{
head2->next=emp1;
head2=emp1;
}
head2->next=NULL;
}
fclose(fp);
fp==NULL;
if((fp=fopen(“学生信息.dat”,“rb”))==NULL)
printf(“n打开系统文件失败!n”);
//
//if(feof(fp)==1)
// {
printf(“还未添加学生信息,请添加学生信息!”);
inputs();
while(!feof(fp))
{
emp1=(struct student*)malloc(sizeof(struct student));
if(emp2==NULL)
{
printf(“n分配内存失败!n”);
return;
}
fread(emp2,sizeof(struct student),1,fp);
if(feof(fp))break;
if(head3==NULL)
{
head3=emp2;
head4=emp2;
}
else{
head4->next=emp2;
head4=emp2;
}
head4->next=NULL;
}
fclose(fp);
fp==NULL;
printf(“n请输入菜单选项(1~6):n”);
scanf(“%d”,&i);
switch(i)
{
case(1):
{
system(“cls”);
inputc();
break;
}
case(2):
{
system(“cls”);
managementc();
break;
}
case(3):
{
system(“cls”);
inputs();
break;
}
case(4):
{
system(“cls”);
managements();
break;
}
case(5):
{
system(“cls”);
store();
break;
}
case(6):
{
system(“cls”);
printf(“感谢使用本系统!nn再见!n”);
}
}
return 1;
}
第三篇:C语言课程设计
C语言课程设计
飞机空战小游戏
一、实验环境
运行系统 WINDOWSXP 编程工具C++6.0 地点 程序设计与仿真实验室
桌号19电脑IP地址221.12.10.218
二、实验目的和要求 实验目的:
(1)使学生进一步理解和掌握课堂上所学各种基本抽象数据类型的逻辑结构、存储结构和操作算法。
(2)使学生进一步掌握程序设计、编写、调试能力。(3)使学生了解软件开发的基本步骤和内容。
实验要求::飞机空战小游戏。功能要求:
1)有主菜单界面,能让用户选择开始、退出、难度等级、查看用户积分功能;
2)飞机能通过A、S、D、W或上下左右键控制移动方向,使用空格键发射子弹;
3)屏幕随机出现从上到下的敌方子弹; 4)当打中敌方子弹时,积分加1;
5)当敌方子弹打正飞机时,游戏结束,并提示用户是否保存记录(记录包括用户名及积分值),保存后退回到主菜单;
6)当选择主菜单中的“查看用户积分”选项时,进入第二级菜单,用户可查看全部用户积分记录,也可仅查看积分最高者,也可根据用户输入的用户名查看;(此处要求使用到链表,用于临时存储用户积分数据);(对链表的查找操作)
7)所有用户积分信息使用文件进行永久性保存; 8)用户选择“难度等级”,可设定游戏不同难度,难度越高,出现敌方子弹数目及间隔将增加。
三、实验内容和结果
系统总体设计:编写出c语言代码,运行程序,并调试程序,最终实现游戏的功能。本程序主要包含游戏控制函数、设置是否继续游戏函数、输出函数、子弹移动函数、敌机移动函数、设置函数、菜单函数等7个主要函数,包含了不同的功能,对原来的程序作出了很大的改进,用到的主要语句有if语句,for语句、while语句、printf语句、switch语句等等,添加了颜色函数。
系统模块设计:包含游戏控制函数、设置是否继续游戏函数、输出函数、子弹移动函数、敌机移动函数、设置函数、菜单函数等7个主要函数,其中是否继续游戏函数,菜单函数主要运用了SWITCH语句和If语句,子弹移动函数,敌机移动函数通过数组内各数值的变化来完成,设置函数主要用PRINTF和SCANF语句进行各项数值的设置,游戏控制函数使用if函数,kbhit()函数,switch函数组合控制数组中飞机进行的移动和图案的变换。最后用打印数组的方式打印出数组变换。最后运用SWITCH函数进行各项菜单内容的操作。
实验的测试和结果:
四、实验中的问题及心得
通过本次试验,使我对c语言有了更深一层次的了解,对for语句、while语句、printf语句、switch语句、颜色函数等等的了解及使用更加详细了一些,明白了这些语句的用法,明确了c语言的使用环境,功能。同时我了解到了一些方法来实现一些C语言作为一个基础性编程语言是我们在以后编程中不可或缺的语言,使用率肯定会进一步增高。掌握了c语言就相当于掌握了一门技术,同时c语言相对而言简单一些,更容易理解。自己虽然对这个小游戏进行一部分的改造,但是我也感觉这只是其中的很很小的一部分,肯定会有更加强大的功能等待着我们去改善。
同时,我也发现了自己很多的不足,需要进一步加强这一方面的学习,在数据结构链表的使用上还很欠缺,无法使用链表进行数据的读取和输入,还有在两个程序的连接上还有困难,对于头文件的理解不到位,链表的结构,定义,使用指针的方式„„这些都需要提高。这些技能的欠缺导致了在 这个小游戏中无法顺利完成有关用户名和记录的一些要求。„„
附录:程序清单
#include
void movebul(int [][N]);//子弹移动函数 void movepla(int [][N]);//敌机移动函数 void setting(void);//设置函数 void menu();//菜单 int scr[50][N]={0},pl=9,width=15,speed=16,density=40,score=0,death=0,length=18,y=0,x=5,z=15,life=1,max=0;//全局变量:界面、我机初始位、界面宽度、敌机速度、敌机密度、得分、死亡,子弹,飞机,敌机初始图案,生命
char name[N];char first[N];void main(){ menu();getch();}
void print(int a[][N])//输出函数 { int i,j;system(“cls”);for(i=0;i a[i][width-1]=4; for(j=0;j { if(a[i][j]==0)printf(“ ”); if((a[i][j]==1)&&(x<15))printf(“%c”,x);//输出我机的符号 if((a[i][j]==2)&&(z<35))printf(“%c”,z);//子弹 if((a[i][j]==3)&&(y<4))printf(“%c”,y+1);//输出敌机符号 if(i==1&&j==width-1)printf(“总积分:%d”,score);//显示得分 if(i==2&&j==width-1)printf(“已经死亡了%d 次,剩余 %d 条命”,death,life-death);//右上角显示死亡次数 if(i==3&&j==width-1)printf(“普通按键:AD控制左右飞行”); if(i==4&&j==width-1)printf(“ W 发射子弹”);if(i==5&&j==width-1)printf(“特殊按键:+-号加减敌机速度”);if(i==6&&j==width-1)printf(“ /*号单列敌机密度减小增大(均有限制)”); if(i==7&&j==width-1)printf(“VIP按键:X键变化飞机图案,Y键变化敌机图案”); if(i==8&&j==width-1)printf(“tZ键变化子弹图案,P键增加生命(均有限制)”); if(i==9&&j==width-1)printf(“注意:向下移动后按其他方向键飞机显现”); } printf(“n”);} } void movebul(int a[][N]){ int i,j;for(i=0;i { if(i==0&&a[i][j]==2) a[i][j]=0; if(a[i][j]==2) { if(a[i-1][j]==3)//加分 { score+=1; printf(“7”); } a[i][j]=0,a[i-1][j]=2; } } } void movepla(int a[][N]){ int i,j;for(i=length-1;i>=0;i--)//从最后一行往上是为了避免把敌机直接冲出数组。 for(j=0;j if(i==length-1&&a[i][j]==3) a[i][j]=0;//消除敌机,在最低层 if(a[i][j]==3)a[i][j]=0,a[i+1][j]=3;//敌机移动 } if(a[length-2][pl]==3&&a[length-1][pl]==1)death++;//死亡 } void continuegame()//继续游戏 { printf(“用户%s”,name);printf(“你的得分是%dn”,score);if(score==0)printf(“tttt 恭喜你刷新了最低记录na”,score);if((score>0)&&(score<20)) printf(“tttt 回家再练 练吧na”,score);if(score>19) printf(“tttt 你真厉害 na”,score);printf(“游戏结束n”);printf(“按y键继续游戏,空格键退出游戏(y/n)?n”);printf(“ttt”);switch(getch())//是否要继续游戏 { case 'y': case 'Y':system(“cls”),death=0,score=0,life=1,x=5,y=0,z=15;menu();break;} } void setting(void)//设置函数 { system(“cls”);//清屏 printf(“n 输入游戏界面的大小(默认3):1-10 ”);scanf(“%d”,&width);width=(width+1)*5;printf(“n 请输入敌机密度大小(默认3):1-5 ”);scanf(“%d”,&density);density=(7-density)*10;printf(“n 输入敌机的飞行速度大小(默认3):1-10 ”);scanf(“%d”,&speed);speed=(11-speed)*2;printf(“n 输入我机的生命(默认1):1-100 ”);scanf(“%d”,&life);printf(“n 输入飞机的图案(默认1):1-2 ”);scanf(“%d”,&x);x=x+4;printf(“n 输入子弹的图案(默认1):1-10 ”);scanf(“%d”,&z);z=z+14;printf(“n 输入敌机的图案(默认1):1-3 ”);scanf(“%d”,&y);y=y-1;} void run(){ int i=0,j=0,k=0,b=0;printf(“请输入用户名:”);scanf(“%s”,name);printf(“您的用户名是:%s”,name);if(getch()==27)setting();printf(“游戏说明:按AWSD控制我机左右飞行,空格键发射子弹n特殊按键:-号敌机减速,+号敌机加速n特殊按键:/号单列敌机密度减小,*号单列敌机密度增大n”);printf(“VIP按键:X键变化飞机图案,Y键变化敌机图案ntZ键变化子弹图案,P键增加生命n”);printf(“任意键开始游戏,esc键进入游戏设置n”);printf(“游戏时也可更改游戏设置任意键开始nn”);system(“color a”);//设置背景颜色 if(getch()==27)setting();scr[length-1][pl]=1;//我方飞机初始位置 scr[0][5]=3;while(death { if(kbhit()) switch(getch())//控制设置按键 { case 'a': case 'A':if(pl>0) scr[length-1][pl]=0,scr[length-1][--pl]=1;break; case 'd': case 'D':if(pl scr[length-1][pl]=0,scr[length-1][++pl]=1;break;case 'W': case 'w':if(length>10) { scr[length-1][pl]=0,scr[length-2][pl]=1; length=length-1; };break; case '+':if(speed>2) { speed=speed-2; };break; case '-':speed=speed+1;break;case '*':if(density>5) { density=density-5; };break; case '/':density=density+10;break; case 'l':if(width<40) { width=width+2; };break; case 's':if(length<30) { scr[length-1][pl]=0; length=length+1; scr[length-1][pl]='5'; };break; case ' ':scr[length-2][pl]=2;break; case 'y':y=(y+1)%4;break; case 'x':x=(x)%2+5;break; case 'z':if(z<25) { z=z+1; } else z=15;break; case 'p':life=life+1;break;} if(++j%density==0)//控制生产敌机的速度 { j=0; srand(time(NULL));//产生随机数 scr[0][rand()%width]=3; scr[rand()%3][rand()%(width+2)]=3; scr[rand()%2][rand()%(width+1)]=3; scr[rand()%4][rand()%(width+4)]=3;//生成随机敌方飞机 } if(++i%speed==0)//控制敌机移动速度,相对于子弹移动速度 movepla(scr);//飞机移动 movebul(scr);//子弹移动 print(scr);//绘制游戏画面 } if(score>=max){ max=score; for(i=0;i { name[i]=first[i]; } } if(score score=score;} continuegame();getch();} void menu(){ printf(“n1:游戏设置n2:游戏说明n3:开始游戏n4:查看用户信息n5:退出游戏n”); switch(getch()){ case '1': setting();menu();break; case '2':printf(“游戏说明:按AWSD控制我机左右飞行,空格键发射子弹n特殊按键:-号敌机减速,+号敌机加速n特殊按键:/号单列敌机密度减小,*号单列敌机密度增大n”);printf(“VIP按键:X键变化飞机图案,Y键变化敌机图案ntZ键变化子弹图案,P键增加生命n”);printf(“ 任意键开始游戏,esc键进入游戏设置n”);printf(“ 游戏时也可更改游戏设置”);menu();break; case '3':run();menu();break; case '4':seerecord();menu();break; case '5':exit(0);break;default:menu();break;} } seerecord(){ printf(“最高纪录为%s,%d”,first[N],max);} 前言 让自己所学的知识应用于实际生活中,理论联系生活,学以致用,我们将更好服务于民。我们是新一代的年轻人,要想将来在社会上更好的立足,就必须让自己强大起来,努力的学习新东西,了解新事物,跟上时代的步伐,这样我们才能与时俱进,不被社会所淘汰。C语言在大学里是一门很重要的课程,也是一门很实用的课程,学好C语言在当今的信息时代是一个很好的敲门砖。而且,我们是电子信息工程专业的,更应该学好C语言,这对我们以后走向社会有很大的帮助,为我们以后大学毕业去求职提升竞争力。从C语言产生到现在,它已经成为最重要和最流行的编程语言之一。在各种流行编程语言中,都能看到C语言的影子,如Java的语法与C语言基本相同。学习、掌握C语言是每一个计算机技术人员的基本功之一。C语言具有高级语言的强大功能,却又有很多直接操作计算机硬件的功能(这些都是汇编语言的功能),因此,C语言通常又被称为中级语言。学习和掌握C语言,既可以增进对于计算机底层工作机制的了解,又为进一步学习其他高级语言打下了坚实的基础。需求分析 当今社会是信息社会,谁的信息越快速越准确,谁就会更好的生活在这个社会上,他的人生也将走向成功。信息业正在21世纪扮演着越来越重要的角色,也是中国十二五规划中的重要一环,因此,我们应该努力的去学习好这门课程,力争在以后的生活工作中大展身手。现在的社会日新月异,各种信息在不断的传递交流,谁最先获取了信息谁就会成功。所以,作为我们这类专业的人才,在毕业以后一定会大显身手,实现自己的人生价值。 2.1 课程设计目的 本课程设计为信息类公共课《计算方法与程序设计》配套的课程设计。是该课程的理论学习的延伸。通过本课程设计有助于锻炼综合运用C语言相关知识设 为1;若n大于1,则开始循环运算(见图3.22流程图),直到i小于n不成立时结束循环。在循环运算的过程中,要调用两个函数即函数pit1和函数pit2(见图3.23流程图)。在调用函数pit1和函数pit2中,这两个函数进行相互递归调用。最后将调用函数pit1和pit2的值返回主函数main函数中,再输出高能质子数目t3和低能质子数目t4。 3.1 系统流程图 程序一系统流程图(如图3.11所示): 开始输入nt1=3,t2=1,i=1否n==0否是n==1是否i 3.2主要模块的流程图 程序一模块流程图如图3.21所示: 否i 图3.21流程图 程序二模块流程图如图3.22和图3.23所示: i=1否i 图3.22流程图 } {t3=3*t1+2*t2;t4=t1+t2;t1=t3;t2=t4;} printf(“n the high=%d the low=%dn”,t3,t4); 程序代码4.1 程序二代码如下所示: #include “stdio.h” int pit1(int a){ if(a==1) } int pit2(int b){ if(b==1) } main(){ int n,i,t3,t4;printf(“n input n”);scanf(“%d”,&n);if(n==0){ return(1);return(pit1(b-1)+pit2(b-1));else return(3);return(3*pit1(a-1)+2*pit2(a-1));else 图5.11 程序二运行结果:如图5.12(程序运行时,当输入时间变量n是3时,输出高能粒子是41,低能粒子是15。) 图5.12 参考文献 [1 ]张福祥.C语言程序设计[M].辽宁大学出版社,2008.[2] 张福祥,王萌.C语言程序设计习题解答与实验实训.沈阳:辽宁大学出版社,2008. [3] 牛莉,刘远军等.计算机等级考试辅导教程[M].北京:中国铁道出版社,2008. [4]李勇帆,谢兵.大学计算机应用教程.北京:中国铁道出版社,2009. [5]田淑清.全国计算机等级考试二级教程.北京:高等教育出版社,2011. [6]杨振山,龚沛曾.大学计算机基础.北京:高等教育出版社,2006. [7]卢湘鸿.信息技术应用基础.北京:高等教育出版社,2004. 致 谢 在这次课程设计的撰写过程中,我得到了许多人的帮助。首先我要感谢我的老师在课程设计上给予我的指导、提供给我的支持和帮助,这是我能顺利完成这次报告的主要原因,更重要的是老师帮我解决了许多技术上的难题,让我能把系统做得更加完善。在此期间,我不仅学到了许多新的知识,而且也开阔了视野,提高了自己的设计能力。其次,我要感谢帮助过我的同学,他们也为我解决了不少我不太明白的设计商的难题。同时也感谢学院为我提供良好的做毕业设计的环境。最后再一次感谢所有在设计中曾经帮助过我的良师益友和同学。 一 问题描述与分析 假定有n门课程,每门课程有课程编号,课程名称,课程性质,总学时,授课学时,实验或上机学时,学分,开学学期等信息,学生可按要求(如总学分不得少于60)自由选课。试设计学生选修课程系统,使之能提供以下功能: 1.课程信息录入功能(课程信息用文件保存)2.课程信息浏览功能 3.排序:按总学时排序 4.查询功能:按开学学期查询 5.课程修改,删除(可选项) 二 总体设计 根据题目要求,定义结构体类型如下: struct subjects { char no[10];char name[20];char kind[20];int stime; /*总学时*/ int ttime; /*授课学时*/ int etime; /*实验或上机学时*/ float score;int term;}sub[N]; 三 详细设计 1)存储结构的选择 在这个程序中,我们选择用结构体数组来存储课程,即顺序存储结构 Struct subjects sub[N] 2)系统初始化 这个模块的主要功能是得到初始的课程。为了实现“一次输入,多次使用”,我们用文件来保存课程。第一次运行本程序需从键盘输入所有课程并保存到文件中,以后运行就可以从文件中读取数据,直接使用了。这样既可以减少输入的麻烦,更重要的是使本程序可以连续运行,每次运行都可以使用上一次保存的结果。void newfile(){ int i;FILE *fp;if((fp=fopen(“sub.dat”,“wb”))==NULL){ printf(“文件建立失败!请重新运行程序。n”); exit(0); } } printf(“请输入课程门数”);scanf(“%d”,&num);for(i=0;i 3)课程浏览功能 按课程编号进行浏览 void read1(){ FILE *fp;num=0;fp=fopen(“sub.dat”,“r”);if(fp==NULL){ printf(“文件打开失败!请重新运行程序。n”); exit(0);} while(!feof(fp)){ fread(&sub[num],1,sizeof(struct subjects),fp); num++;} num--;fclose(fp);printf(“现在共有%d门课程,初始数据为:n”,num);output();} 3 4)排序 按总学时排序:使用改进的起泡法排序。void sortstime(){ int i,j,flag;struct subjects temp;for(i=0;i flag=0; for(j=0;j if(sub[j].stime { temp=sub[j]; sub[j]=sub[j+1]; sub[j+1]=temp; flag=1; } if(flag==0) break;}printf(“排序后的课程为:n”);output();} 4 5)查找(总学时) 按开学学期查询,查找用顺序查找法。void find(){ int i,cterm;printf(“请输入要查找课程的开学学期:n”);getchar();scanf(“%d”,&cterm);i=findterm(cterm);if(i==-1) printf(“要查找的学期不存在:n”);else { printf(“查找到的课程信息为:n”); printf(“课程编号,课程名称,课程性质,总学时,授课学时,实验或上机学时,总学分,开学学期:n”); printf(“===================================n”); printf(“%st%-10st%st%dt%dt%dt%.1ft%dt”,sub[i].no,sub[i].name,sub[i].kind,sub[i].stime,sub[i].ttime,sub[i].etime,sub[i].score,sub[i].term); printf(“n”);} } int findterm(int cterm[]){ } int i;for(i=0;i<=num;i++)if(cterm-sub[i].term==0) return i;return-1; 6)参考文献 C语言指导书。7)心得体会 通过对课程精心设计,我从中获得了不少东西: 1.我知道一些自己不太熟悉的知识,比如文件系统中的好多知识; 2.从中懂得了合作的重要性,这是以前没注意的; 3.也锻炼了自己的思维能力,可以把一整块东西分成若干个小块来处理; 4.在锻炼的同时,自己得到了一种满足感。第四篇:C语言课程设计
第五篇:C语言课程设计说明书