兰交大C语言11级课设.docx
- 文档编号:4690818
- 上传时间:2022-12-07
- 格式:DOCX
- 页数:27
- 大小:318.63KB
兰交大C语言11级课设.docx
《兰交大C语言11级课设.docx》由会员分享,可在线阅读,更多相关《兰交大C语言11级课设.docx(27页珍藏版)》请在冰豆网上搜索。
兰交大C语言11级课设
C语言课程设计
专业:
自动控制
班级:
控xxxx
姓名:
xxxxxxxx
学号:
20xxxxxxx
指导教师:
董昱
评语:
平时(40)
修改(30)
报告(30)
总成绩
兰州交通大学自动化与电气工程学院
2012年7月6日
1基本题目
1.1题目
判断一个数是否是数组中的成员(用二分法查找)
已知数据a中一共有10个已排序的整数(由小到大排列)。
现在从键盘上输这个数是否是数组a中的数,如果是的话,打印出此数在数组a中的位置来,否则打印“找不到“。
1.2题目分析
用查找关键字x与中间位置的元素比较,这个中间位置元素将查找范围一分为二,若比较结果相等则查找成功;若不相等,再根据x与中间位置元素比较的结果确定下一步查找范围:
如果x比中间元素大,则在中间位置右半边查找;否则,在中间位置元素左半边查找。
这样不断进行下去,直到找到满足条件的元素或者该数组中没有这样的元素为止。
对题目进行分析,画出流程图如图1.2.1所示。
图1.2.1基本题流程图1.3程序
#include
voidmain()
{
intx,l=0,m,h=9,a[10]={1,2,3,4,5,6,7,8,9,10};
scanf("%d",&x);
m=(l+h)/2;/*找到查找范围的中间位置*/
while(a[m]!
=x&&l<=h)
{
if(a[m]>x)
h=m-1;/*缩小查找范围为左半区*/
else
l=m+1;/*缩小查找范围为右半区*/
m=(l+h)/2;
}
if(a[m]==x)
printf("位置:
%d",m+1);
else
printf("找不到");
}
1.4程序的运行结果
上述程序运行结果如图1.4.1所示。
图1.4.1基本题目运行结果
2改错题目
下列给定程序中,函数fun的功能是:
依次取出字符串中所有数字字符,形成新的字符串,并取代原字符串。
请改正程序中的错误,使程序能得出正确的结果。
注意,不要改多main函数,不得增行或删行,也不得更改程序的结构。
程序如下:
#include
#include
voidfun(char*s)
{
inti,j;
for(i=0,j=0;s[i]!
='\0';i++)
if(s[i]>='0'&&s[i]<='9')/*s[j]=s[i]改为{s[j]=s[i];j++;}*/
s[j]=s[i];
s[j]="\0";/*s[j]="\0"改为s[j]='\0'*/
}
main()/*main前加void*/
{
charitem[80];
clrscr();/*clrscr()前加void*/
printf("\nEnterastring:
");
gets(item);
printf("\n\nThestringis:
\%s\n",item);/*\%s改为%s*/
fun(item);
printf("\n\nThestringofchangingis:
\%s\n",item);/*\%s改为%s*/
}
2.1改正后程序
#include
#include
voidfun(char*s)
{
inti,j;
for(i=0,j=0;s[i]!
='\0';i++)
if(s[i]>='0'&&s[i]<='9')
{
s[j]=s[i];
j++;
}
s[j]='\0';
}
voidmain()
{
charitem[80];
voidclrscr();
printf("\nEnterastring:
");
gets(item);
printf("\n\nThestringis:
%s\n",item);
fun(item);
printf("\n\nThestringofchangingis:
%s\n",item);
}
2.2程序运行结果
上述程序的运行结果如图2.2.1所示。
图2.2.1改错题流程图
功能说明:
输入一个字符串,输出该字符串,然后运用fun功能取代原字符串,只输出数字字符串。
3综合题目
3.1题目
班级档案管理系统
一、问题描述:
对一个有N个学生的班级,通过该系统实现对该班级学生的基本信息进行录入、显示、修改、删除、保存等操作的管理。
二、功能要求:
本系统采用一个包含N个数据的结构体数组,每个数据的结构应当包括:
学号、姓名、性别、年龄、备注。
本系统显示这样的菜单:
请选择系统功能项:
a.学生基本信息录入
b.学生基本信息显示
c.学生基本信息保存
d.学生基本信息删除
e.学生基本信息修改(要求先输入密码)
f.学生基本信息查询
(1)按学号查询
(2)按姓名查询
(3)按性别查询
(4)按年龄查询
g.退出系统
执行一个具体的功能之后,程序将重新显示菜单。
将学生基本信息保存到文件中。
进入系统之前要先输入密码。
三、算法提示:
数据结构:
结构体类型数组
数据库结构:
下表构成该系统的基本数据库。
姓名学号性别年龄备注
charcharcharintchar
四、测试数据:
学生人数N=10
五、其它:
对该系统有兴趣的同学可以在实现上述基本功能后,完善系统的其它功能。
3.2数据结构
对上述题目进行分析,定义结构体数据结构如下:
姓名
学号
性别
年龄
备注
char
char
char
int
char
3.3程序主要功能
实现基本的班级档案信息管理,如:
学生基本信息的录入、学生基本信息的显示、学生基本信息的保存、学生基本信息的删除、学生基本信息的修改基本信息的查询(分别使用了menu(),input(),display(),del(),add(),search(),save(),modify()等函数)。
其中学生信息的删除要先输入密码,学生信息的查询又可通过不同的方式如按学号、姓名、性别、年龄进行操作。
在执行一个具体的功能之后,程序重新显示菜单。
对题目进行分析,画出流程图如图3.3.1所示。
图3.3.1班级系统管理流程图
3.4各函数的功能
(1)menu()
该函数主要用printf语句定义来显示主界面内容。
(2)input()
该函数定义程序密码,进入改程序必须先输入密码。
该函数中主要运用了字符串比较函数strcmp,若用户输入密码正确,程序继续执行进入主菜单;若密码错误提示“密码错误”以及输入学生信息。
(3)save()
该函数用于学生信息的保存,如果不保存将会丢失,造成很大的麻烦,即必须重新输入信息。
(4)display()
该函数作用是显示学生录入信息,运用for循环输出学生的基本信息。
(5)del()
该函数实现对输入信息的删除。
用户可根据提示输入想要删除的学生学号进行删除。
(6)add()
该函数可对文件的数据进行添加。
在进行添加的时候需要首先打开数据文件,在该函数中调用指针*fp将数据文件打开。
输入学生信息,由于插入点在文件末尾,输入的信息添加到文件后面。
(7)search()
该函数的作用是对信息查询。
用户可根据需要自主选择查询方式,如按学号查询、按姓名查询等。
以按学号查询为例,用户输入要查询学生的学号,程序通过循环比较将查询结果输出,若没有对应的信息,则提示“未找到对应结果”。
(8)modify()
该函数实现对输入信息的修改。
修改前先要输入密码,密码正确才可以修改。
用户输入要修改学生的学号后,根据提示输入新的学生信息,程序用字符串复制函数strcpy把新信息复制到文件中。
3.5源程序
#include
#include
#include
#include
#include
#defineN100
structstudent
{
intnum;
charname[10];
charsex[10];
intage;
charbeizhu[50];
}
st[100];/*定义一个结构体*/
voidmenu();
voidinput();
voidsave(int);
voiddisplay();
voiddel();
voidadd();
voidsearch();
voidsearch_num();
voidsearch_name();
voidsearch_sex();
voidsearch_age();
voidmodify();/*定义各函数*/
voidmenu()/*菜单函数*/
{
system("color1F");
printf("☆☆☆自动控制☆☆☆\n");
printf("\n");
printf("∮***自控1103班欢迎你***∮\n");
printf("\n");
printf("******************学生档案管理****************\n");
printf("1.录入学生信息");
printf("2.显示学生信息\n");
printf("3.查询学生信息");
printf("4.删除学生信息\n");
printf("5.添加学生信息");
printf("6.修改学生信息\n");
printf("7.退出\n");
printf("********************谢谢使用******************\n");
printf("\n");
printf("\n");
}
voidmain()
{
intcount=0;
charm[10]={"123"};/*定义密码*/
charn[20];
printf("请输入密码\n");
scanf("%s",n);
if(strcmp(m,n)==0)//字符串比较函数
printf("欢迎你来到自控1103班\n");
else
{
printf("密码错误\n");exit(0);
}
{
menu();/*调用菜单函数*/
intn,flag;
chara;
do
{
printf("请选择你需要操作的步骤(1--7):
\n");
scanf("%d",&n);
if(n>=1&&n<=7)
{
flag=1;
break;
}
else
{
flag=0;
printf("您输入有误,请重新选择!
\n");
break;
}
}
while(flag==0);
while(flag==1)
{
switch(n)
{
case1:
printf("◆◆◆输入学生信息◆◆◆\n");printf("\n");input();break;
case2:
printf("◆◆◆显示学生信息◆◆◆\n");printf("\n");display();break;
case3:
printf("◆◆◆按学号查询学生信息◆◆◆\n");printf("\n");search();break;
case4:
printf("◆◆◆删除学生信息◆◆◆\n");printf("\n");del();break;
case5:
printf("◆◆◆添加学生信息◆◆◆\n");printf("\n");add();break;
case6:
printf("◆◆◆修改学生信息◆◆◆\n");printf("\n");modify();break;
case7:
exit(0);
default:
break;
}
getchar();
printf("\n");
printf("是否继续进行(yorn):
\n");
scanf("%c",&a);
if(a=='y')
{
flag=1;
system("cls");/*清屏*/
menu();/*调用菜单函数*/
printf("请再次选择你需要操作的步骤(1--7):
\n");
scanf("%d",&n);
printf("\n");
}
else
exit(0);
}
}
}
voidinput()/*录入函数*/
{
inti,m;
printf("请输入需要创建信息的学生人数(1--100):
\n");
scanf("%d",&m);
for(i=0;i { printf("请输入学号: "); srand((int)time(0)); st[i].num=rand()%10000+20000000; scanf("%d",&st[i].num); printf("请输入姓名: "); scanf("%s",st[i].name); getchar(); printf("请输入性别: "); scanf("%s",st[i].sex); printf("请输入年龄: "); scanf("%d",&st[i].age); printf("请输入备注: "); scanf("%s",&st[i].beizhu); printf("\n"); } printf("\n创建完毕! \n"); save(m); } voidsave(intm)/*保存文件函数*/ { inti; FILE*fp; if((fp=fopen("d: \\student.txt","wb+"))==NULL) { printf("cannotopenfile\n"); exit(0); } for(i=0;i if(fwrite(&st[i],sizeof(structstudent),1,fp)! =1) printf("filewriteerror\n"); fclose(fp); } intload()/*导入函数*/ { FILE*fp; inti=0; if((fp=fopen("d: \\student.txt","rb"))==NULL) { printf("cannotopenfile\n"); exit(0); } else { do { fread(&st[i],sizeof(structstudent),1,fp); i++; } while(feof(fp)==0); } fclose(fp); return(i-1); } voiddisplay()/*显示函数*/ { inti; intm=load(); printf("\n学号\t姓名\t性别\t年龄\t备注\n"); for(i=0;i printf("\n%-14d%s\t%s\t%d\t%s\n",st[i].num,st[i].name,st[i].sex,st[i].age,st[i].beizhu); } voiddel()/*删除函数*/ { intm=load(); inti,j,n,t,flag; charname[20]; printf("\n原来的学生信息: \n"); display();/*调用显示函数*/ printf("\n"); printf("请输入要删除的学生的姓名: \n"); scanf("%s",name); for(flag=1,i=0;flag&&i { if(strcmp(st[i].name,name)==0) { printf("\n已找到此人,原始记录为: \n"); printf("\n学号\t姓名\t性别\t年龄\t备注\n"); printf("\n%d\t%s\t%s\t%d\t%s\n",st[i].num,st[i].name,st[i].sex,st[i].age,st[i].beizhu); printf("\n确实要删除此人信息请按1,不删除请按0\n"); scanf("%d",&n); if(n==1)/*如果删除,则其他的信息都往上移一行*/ { for(j=i;j { strcpy(st[j].name,st[j+1].name); st[j].num=st[j+1].num; strcpy(st[j].sex,st[j+1].sex); st[j].age=st[j+1].age; strcpy(st[j].beizhu,st[j+1].beizhu); } flag=0; } } } if(! flag) m=m-1; else printf("\n对不起,查无此人! \n"); printf("\n浏览删除后的所有学生信息: \n"); save(m);/*调用保存函数*/ display();/*调用显示函数*/ printf("\n继续删除请按1,不再删除请按0\n"); scanf("%d",&t); switch(t) { case1: del();break; case0: break; default: break; } } voidadd()/*添加函数*/ { FILE*fp; intn; intcount=0; inti; intm=load(); printf("\n原来的学生信息: \n"); display();/*调用显示函数*/ printf("\n"); fp=fopen("student_list","ab+"); printf("请输入想增加的学生数: \n"); scanf("%d",&n); for(i=m;i<(m+n);i++) { printf("\n请输入新增加学生的信息: \n"); printf("请输入学号: "); scanf("%d",&st[i].num); printf("请输入姓名: "); scanf("%s",st[i].name); getchar(); printf("请输入性别(: "); scanf("%s",st[i].sex); printf("请输入年龄: "); scanf("%d",&st[i].age); printf("请输入备注: "); scanf("%s",st[i].beizhu); printf("\n"); count=count+1; printf("已增加的人数: \n"); printf("%d\n",count); } printf("\n添加完毕! \n"); m=m+count; printf("\n显示增加后的所有学生信息: \n"); printf("\n"); save(m); display(); fclose(fp); } voidsearch()/*查询函数*/ { intt,flag; do { printf("\n按学号查询请按1,按姓名查询请按2,按性别查询请按3,按年龄查询请按4,进入主函数按5\n"); scanf("%d",&t); if(t>=1&&t<=5) { flag=1; break; } else { flag=0; printf("您输入有误,请重新选择! "); } } while(flag==0); while(flag==1) { switch(t) { case1: printf("按学号查询\n");search_num();break; case2: printf("按姓名查询\n");search_name();break; case3: printf("按性别查询\n");search_sex();break; case4: printf("按年龄查询\n");search_age();break; case5: main(); } } } voidsearch_num() { intnum; inti,t; intm=load(); printf("请输入要查找的学号: \n"); scanf("%d",&num); for(i=0;i if(num==st[i].num) { printf("\n已找到此人,其记录为: \n"); printf("\n学号\t姓名\t性别\t年龄\t备注\n"); printf("\n%d\t%s\t%s\t%d\t%s\n",st[i].num,st[i].name,st[i].sex,st[i].age,st[i].beizhu); break; } if(i==m) printf("\n对不起,查无此人\n"); printf("\n"); printf("返回查询函数请按1,继续查询学号请按2\n"); scanf("%d",&t); switch(t) { case1: search();break; case2: break; default: break; } } voidsearch_name() { charname[10]; inti,t; intm=load(); printf("请输入要查找的姓名: \n"
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 交大 语言 11 级课设