第一篇:学生信息管理系统实训(C语言)
#include
void lookup(int snum[],int sc[],int length);
void summary(int sc[],int length);
void change(int n,int snum[],int sc[],int length);void search(int n,int snum[],int sc[],int length);void input(int snum[],int sc[],int length);
void main()
{
int snumber[5];
int score[5];
int choice;
int password;
char usename;
int i=0,j=0,sum=0,min=100,max=0,x=0,flag=0;int number;
cout<<“**********************”<<'n';cout<<“欢迎使用学生信息管理系统”<<'n';cout<<“**********************”<<'n';cout<<“1.登陆”<<'n';
cout<<“2.退出”<<'n';
cout<<“3.请选择:”< cin>>choice; if(choice==1) { do { cout<<“请输入用户名”<<'n'; cin>>usename; cout<<“请输入密码”< cin>>password; if(usename!='1'||password!=123) cout<<“用户名或密码错误,请重新输入”< do { cout<<“欢迎使用学生信息管理系统”<<'n';cout<<“**********************”<<'n';cout<<“1.学生信息输入 ”<<'n'; cout<<“2.学生信息查看”<<'n'; cout<<“3.学生信息查找”<<'n'; cout<<“4.学生信息修改 ”<<'n'; cout<<“5.汇总”<<'n'; cout<<“6.退出 ”<<'n'; cout<<“请选择:”< cin>>choice; switch(choice) { case 1:///输入///// input(snumber,score,5); break; case 2: //////查看////// lookup(snumber,score,5); break; case 3://---查询---// cout<<“输入查询学生学号:”<<'n'; cin>>number;search(number,snumber,score,10);break; case 4: ////修改///// cout<<“输入修改学生学号:”<<'n';cin>>number; change(number,snumber,score,10);break; case 5:////汇总////// summary(score,5); }break; }while(choice!=6); } } ///////////////////////////////////////////////////////////////////// ///////输入 void input(int snum[],int sc[],int length) { int i=0; for(int x=0;x snum[x]=x+1; cout< cin>>sc[x]; } } ////////查找 void search(int n,int snum[],int sc[],int length) { int flag=0; for(int i=0;i {if(n==snum[i]){cout< ////////修改 void change(int n,int snum[],int sc[],int length){ int flag=0;int x;for(int i=0;i if(n==snum[i]) { cout< sc[i-1]=x; flag=1; } }if(flag!=1)cout<<“错误!找不到该学生信息”< } ////////查看 void lookup(int snum[],int sc[],int length) { int i=0,j=0,t,p,x=0,flag=0,choice;cout<<“1.按学号查看”< cout<<“2.按成绩查看”< t=sc[j];p=snum[j]; sc[j]=sc[j+1];snum[j]=snum[j+1];sc[j+1]=t;snum[j+1]=p; } } } for(j=0;j cout< } if(choice==2) { for(i=0;i { for(j=0;j {if(sc[j] { t=sc[j];p=snum[j]; sc[j]=sc[j+1];snum[j]=snum[j+1];sc[j+1]=t;snum[j+1]=p;} }} for(j=0;j cout< } /////////汇总 void summary(int sc[],int length) { inti=0,j=0,sum=0,min=100,max=0;int ave; do{ for(i=0;i<5;i++) { if(sc[i]<60) j++; if(max max=sc[i]; if(min>sc[i]) min=sc[i]; sum=sum+sc[i]; }}while(i>length); ave=sum/length; cout<<“总分为”< cout<<“不及格人数”< cout<<“平均分为”< #include char num[8];/*学号*/ char name[9];/*姓名*/ char gender[3];/*性别*/ int score;/*成绩*/ }DataType; typedef struct { DataType stu[MAXSIZE]; int length;}sequenlist; int menu_select(){ int sn;printf(“n 学生信息管理系统n”);printf(“=========================================n”);printf(“ 1.学生信息顺序表的建立n”);printf(“ 2.插 入 学 生 信 息n”);printf(“ 3.查 询 学 生 信 息n”);printf(“ 4.删 除 学 生 信 息n”);printf(“ 5.输 出 所有学生信息n”);printf(“ 0.退 出 管 理 系 统n”);printf(“==========================================n”); printf(“请选择0-5:n”);for(;;){ scanf(“%d”,&sn);if(sn<0 || sn>5) printf(“nt输入错误,重选0-5n”); else break;} return sn;} void createList(sequenlist *L){ int n,i;printf(“有几位学生?请输入:n”);fflush(stdin);scanf(“%d”,&n);printf(“以下请输入这%d位学生的信息:n”,n);for(i=0;i printf(“第%d位学生:”,i); printf(“n学号(8) 姓名(8)性别 成绩n”); fflush(stdin); scanf(“%s%s%s%d”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,&L->stu[i].score);} L->length=n;} void printList(sequenlist *L){ int i;printf(“n学号(8) 姓名(8)性别 成绩n”);printf(“------------n”);for(i=0;i printf(“第%d位学生:”,i); printf(“%s,%s,%s,%dn”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,L->stu[i].score); printf(“----n”);} } int insert(sequenlist *L,DataType *student,int i){ int j;if(L->length==MAXSIZE){ printf(“overflow!”); return 0;} else if((i<0)||(i>L->length)){ printf(“error,please input the right 'i'”); return 0;} else { for(j=L->length-1;j>=i;j--) { strcpy(L->stu[j+1].num,L->stu[j].num); strcpy(L->stu[j+1].name,L->stu[j].name); strcpy(L->stu[j+1].gender,L->stu[j].gender); L->stu[j+1].score=L->stu[j].score; } strcpy(L->stu[i].num,student->num); strcpy(L->stu[i].name,student->name); strcpy(L->stu[i].gender,student->gender); L->stu[i].score=student->score; L->length=L->length+1; } return 1;} int findList(sequenlist *L){ char num[8];char name[9];int i=0,xz;printf(“===========================n”); printf(“ 1、按学号查询n”);printf(“ 2、按姓名查询n”);printf(“===========================n”);printf(“ 请选择: ”);fflush(stdin);scanf(“%d”,&xz);if(xz==1){ printf(“请输入要查找学生的学号:”); scanf(“%s”,num); for(i=0;i { if(strcmp(L->stu[i].num,num)==0) return i; } } else if(xz==2){ printf(“请输入要查找学生的姓名:”); scanf(“%s”,name); for(i=0;i { if(strcmp(L->stu[i].name,name)==0) return i; } } return-1;/*如果没找到,返回-1。否则直接返回,不会执行本句*/ } void delNode(sequenlist *L){ int i,j; printf(“请先查找您要删除的学生信息:n”);i=findList(L);if(i==-1){ printf(“没有查到要删除的学生信息”); return;} for(j=i;j L->stu[j].score=L->stu[j+1].score; strcpy(L->stu[j].num,L->stu[j+1].num); strcpy(L->stu[j].name,L->stu[j+1].name); strcpy(L->stu[j].gender,L->stu[j+1].gender);} L->length--;printf(“该学生信息已被删除!n”);} void main(){ sequenlist *L; DataType *student; int i; L=(sequenlist *)malloc(sizeof(sequenlist)); while(1){ switch(menu_select()) { case 1: printf(“**************************************n”); printf(“ 学生信息顺序表的建立 n”); printf(“***************************************n”); createList(L); break; case 2: printf(“**************************************n”); printf(“添加学生信息n”); printf(“请输入要添加的学生信息:n”);printf(“n学号(8) 姓名(8)性别 成绩n”); printf(“**************************************n”); student=(DataType *)malloc(sizeof(DataType)); fflush(stdin); scanf(“%s%s%s%d”,student->num,student->name,student->gender,&student->score); printf(“请输入要插入的位置:n”); fflush(stdin); scanf(“%d”,&i); insert(L,student,i); break; case 3: printf(“**************************************n”); printf(“查询学生信息n”); printf(“**************************************n”); i=findList(L); if(i!=-1) { printf(“您要查的学生为:n学号(8) 姓名(8)性别 成绩n”); printf(“------------n”); printf(“%s,%s,%s,%dn”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,L->stu[i].score); printf(“----n”); } else printf(“没有您要查询的学生信息!”); break; case 4: printf(“**************************************n”); printf(“删除学生信息n”); printf(“**************************************n”); delNode(L); break; case 5: printf(“**************************************n”); printf(“输出所有学生信息n”); printf(“**************************************n”); printList(L); break; case 0: printf(“再见!n”);getchar(); return; } } } C语言课程设计报告 班学号: 学号: 姓名: 指导教师: 年 月 C语言课程设计报告 题目要求 基本功能:代理商信息采集、浏览、查询;代理商信息的输入、浏览、修改、查询、统计等。 需求分析 实现代理商信息采集和代理商品信息输入功能,要提供结构体的输入操作;实现统计功能,要提供相应的统计操作;实现查询功能,要提供查找操作;实现修改弄能,要提供修改操作;另外,还要提供键盘式选择菜单以实现功能选择。 总体分析 整个系统应设计为代理商信息采集、浏览、查询;代理商信息输入、浏览、修改、查询、统计等模块。 数据结构 数据结构财通结构体数组。 算法设计 主菜单选择功能,通过判断输入的选择进入相应的处理模块,包括数据输入、数据统计、数据查询、数据删除等。程序流程如下图所示: 数据结构设计 程序定义了一个运营商加入日期的结构体: struct data { }; 定义了运营商信息的结构体: struct acmer { };int number; //运营商的编号; char name[20]; //运营商姓名; char agentnum[20]; //销售量; char phonum[20]; //电话号码; char goods[20]; //商品; struct data time; //加入日期; int year; //运营商加入的年份; int month; //运营商加入的月份; int day; //运营商加入的日期; 模块设计 1.主函数 Main函数通过调用menu函数输入一个数字来选择用什么函数以实现相应功能,同时这个功能通过switch选择结构来调用: int main() { struct acmer agent[100];int n,i,k;printf(“请输入要统计的代理商数目:”);scanf(“%d”,&n);printf(“请输入代理商信息:n”);for(i=1;i<=n;i++)input(i,agent);menu();while(scanf(“%d”,&k),k!=0){ switch(k){ case 1:for(i=1;i<=n;i++) {output(i,agent);}menu();break;case 2:stat(n,agent);menu();break;case 3:search(n,agent);menu();break;case 4:amend(n,agent);menu();break;case 5:sort(n,agent);for(i=1;i<=n;i++) } } { printf(“[%d]”,i);output(i,agent);} menu();break;case 6:n=add(n,agent);menu();break;case 7:cancel(n,agent);menu();break;default:printf(“errorn”);menu();break;} return 0;2.menu函数 Menu函数是用来辅助main函数提供键盘是菜单以实现选择功能的: void menu() { printf(“1 输出n”);printf(“2 统计n”);printf(“3 查找n”);printf(“4 代理商信息修改n”);printf(“5 排名n”);printf(“6 添加n”); } printf(“7 删除n”);printf(“0 结束程序”);3.代理商信息添加模块 首先调用add函数以确定输入代理商的数目,然后用input函数来输入代理商信息: int add(int n,struct acmer agent[]){ void input(int i,struct acmer agent[]){ printf(“姓名:”);scanf(“%s”,agent[i].name);printf(“代理商编号:”);int k,i;printf(“请输入添加代理商数目:”);scanf(“%d”,&k);for(i=n+1;i<=n+k;i++){ } return n+k;input(i,agent); } scanf(“%s”,agent[i].agentnum);printf(“联系方式:”);scanf(“%s”,agent[i].phonum);printf(“销售量:”);scanf(“%d”,&agent[i].number);printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);printf(“年:”);scanf(“%d”,&agent[i].time.year);printf(“月:”);scanf(“%d”,&agent[i].time.month);printf(“日:”);scanf(“%d”,&agent[i].time.day);4.代理商信息浏览 代理商信息浏览使用了output函数,可以同时输出代理商以及商品的所有信息: void output(int i,struct acmer agent[]){ printf(“姓名:%s”,agent[i].name);printf(“代理商编号:%s”,agent[i].agentnum);printf(“联系方式:%s”,agent[i].phonum);printf(“销售量:%d”,agent[i].number);printf(“代理商品信息:%s”,agent[i].goods); 加 盟 时 printf(“间:%d %d %dn”,agent[i].time.year,agent[i].time.month,agent[i].time.day);} 5.数据删除 数据删除也是先读取数据文件中所有现存代理商信息。如果没有读到代理商则表示本身无记录,删除功能无法继续。 删除功能的实现主要在重新写文件时。通过比对需要删除的那条记录与已读取出的存放于结构体数组中的记录,如果相同,则跳过该条记录的重新写入,即重新写文件时,就会少了该条记录,于是完成删除功能。 int cancel(int n,struct acmer agent[]) { char x[20];int i,j,flag,t;t=n;printf(“请输入要删除代理商的编号(按000结束删除):”);while(scanf(“%s,x”)!=EOF){ flag=0; } } if(strcmp(x,“000”)==0)break;for(i=1;i<=n;i++) if(strcmp(x,agent[i].agentnum)==0){ } if(flag==0) printf(“没有找到代理商信息n”);for(j=i+1;j<=n;j++) agent[i]=agent[i+1]; flag=1;t--;break;return t;6.统计功能 统计功能主要统计销售量超过一定数量的运营商,使用了stat函数。若运营商超过给定数值k则输出该运营商信息,若未超过则不输出。void stat(int n,struct acmer agent[]){ int k,i,x; } printf(“1:销售量超过k的代理商n”);printf(“2:排名前k的代理商n”);printf(“3:请选择,按4结束统计:”);while(scanf(“%d”,&x),x!=4){ } printf(“请输入k:”);scanf(“%d”,&k);switch(x){ case 1:for(i=1;i<=n;i++) if(agent[i].number>k) output(i,agent);break;case 2:sort(n,agent);for(i=1;i<=k;i++)output(i,agent);break;default:printf(“errorn”);} 7.修改模块 修改模块使用amend函数,当输入号码与已有号码一致时,输入新的商品信息,覆盖原有信息,若未发现输入号码,则输出“没有找到此人信息”。 void amend(int n,struct acmer agent[]){ } int i,k,flag=0;char x[20];printf(“请输入要修改的代理商编号:”);scanf(“%s”,x);for(i=1;i<=n;i++){ } if(flag==0)printf(“没有找到此人信息n”);if(strcmp(x,agent[i].agentnum)==0){ } break;flag=1;printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);else printf(“修改成功n”);8.查找模块 查找模块提供了两种查找方式,即按姓名查找和按编号查找。前者使用了if(strcmp(x,agent[i].name)==0)语句,后者使用了if(strcmp(x,agent[i].name)==0)语句来实现相应功能。void search(int n,struct acmer agent[]){ int k,i,flag=1;char x[20];printf(“1 按姓名查找”);printf(“2 按编号查找”);printf(“请选择查找方式:”);scanf(“%d”,&k);if(k==1){ printf(“请输入要查找代理商姓名: scanf(”%s“,x); for(i=1;i<=n;i++) if(strcmp(x,agent[i].name)==0) { flag=0; output(i,agent);break; ”); } if(flag==1) printf(“没有此人信息n”);} if(k==2){ printf(“请输入要查找代理商编号: scanf(”%s“,x); if(strcmp(x,agent[i].name)==0) { flag=0; output(i,agent); break; } if(flag==1) printf(”没有此人信息n“);} } 程序 #include ”);{ };struct acmer { };void menu(){ printf(“1 输出n”);printf(“2 统计n”);printf(“3 查找n”);printf(“4 代理商信息修改n”);printf(“5 排名n”);printf(“6 添加n”);int number;char name[20];char agentnum[20];char phonum[20];char goods[20];struct data time;int year;int month;int day; } printf(“7 删除n”);printf(“0 结束程序”);void input(int i,struct acmer agent[]){ } printf(“姓名:”);scanf(“%s”,agent[i].name);printf(“代理商编号:”);scanf(“%s”,agent[i].agentnum);printf(“联系方式:”);scanf(“%s”,agent[i].phonum);printf(“销售量:”);scanf(“%d”,&agent[i].number);printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);printf(“年:”);scanf(“%d”,&agent[i].time.year);printf(“月:”);scanf(“%d”,&agent[i].time.month);printf(“日:”);scanf(“%d”,&agent[i].time.day);void output(int i,struct acmer agent[]){ printf(“姓名:%s”,agent[i].name);printf(“代理商编号:%s”,agent[i].agentnum);printf(“联系方式:%s”,agent[i].phonum);printf(“销售量:%d”,agent[i].number);printf(“代理商品信息:%s”,agent[i].goods);printf(“ 加 盟 时间:%d %d %dn”,agent[i].time.year,agent[i].time.month,agent[i].time.day);} int add(int n,struct acmer agent[]){ } int k,i;printf(“请输入添加代理商数目:”);scanf(“%d”,&k);for(i=n+1;i<=n+k;i++){ } return n+k;input(i,agent);int cancel(int n,struct acmer agent[]){ char x[20];int i,j,flag,t;t=n;printf(“请输入要删除代理商的编号(按000结束删除): while(scanf(”%s,x“)!=EOF){ flag=0; if(strcmp(x,”000“)==0) break; for(i=1;i<=n;i++) if(strcmp(x,agent[i].agentnum)==0) { for(j=i+1;j<=n;j++) agent[i]=agent[i+1]; flag=1; t--; break; } if(flag==0)printf(”没有找到代理商信息n“);”); } } return t;void sort(int n,struct acmer agent[]){ } void stat(int n,struct acmer agent[]){ int k,i,x;printf(“1:销售量超过k的代理商n”);printf(“2:排名前k的代理商n”);printf(“3:请选择,按4结束统计:”);struct acmer t;int i,j;for(i=1;i<=n-1;i++) for(j=1;j<=n-1;j++) if(agent[j].number } t=agent[j];agent[j]=agent[j+1];agent[j+1]=t; } while(scanf(“%d”,&x),x!=4){ } printf(“请输入k:”);scanf(“%d”,&k);switch(x){ case 1:for(i=1;i<=n;i++) if(agent[i].number>k) output(i,agent);break;case 2:sort(n,agent);for(i=1;i<=k;i++)output(i,agent);break;default:printf(“errorn”);} void amend(int n,struct acmer agent[]){ int i,k,flag=0;char x[20];printf(“请输入要修改的代理商编号:”);scanf(“%s”,x); } for(i=1;i<=n;i++){ } if(flag==0)printf(“没有找到此人信息n”);if(strcmp(x,agent[i].agentnum)==0){ } break;flag=1;printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);else printf(“修改成功n”);void search(int n,struct acmer agent[]){ int k,i,flag=1;char x[20];printf(“1 按姓名查找”);printf(“2 按编号查找”);printf(“请选择查找方式:”); scanf(“%d”,&k);if(k==1){ printf(“请输入要查找代理商姓名:”);scanf(“%s”,x);for(i=1;i<=n;i++) if(strcmp(x,agent[i].name)==0) { flag=0; output(i,agent); break; } if(flag==1)printf(“没有此人信息n”);} if(k==2){ printf(“请输入要查找代理商编号: scanf(”%s“,x);if(strcmp(x,agent[i].name)==0) { flag=0; ”); } output(i,agent);break;if(flag==1)printf(“没有此人信息n”);} } int main(){ struct acmer agent[100];int n,i,k;printf(“请输入要统计的代理商数目: scanf(”%d“,&n);printf(”请输入代理商信息:n“);for(i=1;i<=n;i++)input(i,agent);menu();while(scanf(”%d“,&k),k!=0){ switch(k) { case 1:for(i=1;i<=n;i++) ”); } } {output(i,agent);}menu();break;case 2:stat(n,agent);menu();break;case 3:search(n,agent);menu();break;case 4:amend(n,agent);menu();break;case 5:sort(n,agent); for(i=1;i<=n;i++){ printf(“[%d]”,i);output(i,agent);} menu();break;case 6:n=add(n,agent);menu();break;case 7:cancel(n,agent);menu();break;default:printf(“errorn”);menu();break;} return 0; 上机操作 1. 数据源 2. 编译、链接和运行 3. 运行结果 下为各界面图: 主函数 输入板块 浏览板块 在主界面输入1后按enter键 统计板块 在主界面输入2后按enter键 查找板块 在主界面输入后按enter键 添加板块 小结 通过本次实习,我对C语言有了更一步的理解与掌握,这一切离不开老师的教育和同学们的帮助,所以我十分感谢我的老师。本次实习过程中,遇到了不少困难,但本着一颗执着的心,加上老师耐心的帮助,我克服了一个个困难,并最终完成了任务,所以这次的实习对我的帮助很大,不仅在学习上取得了更多了收货,也进一步锻炼了我克服困难的勇气和决心,另外我发现自己C语言的兴趣越来越浓厚,希望在以后的学习生活中能更多机会的接触C语言,并能对C语言有更深一步的了解和掌握。也许会遇到困难,但只要做好每一个步骤,保证每个步骤的准确性,就一定会取得成功。再次谢谢老师的教育和同学们的帮助。 《C语言程序设计》综合实训 一、实训目的: 1、完成C语言程序设计课程的教学之后,通过1周的课程设计可以进一步巩固所学知识,加深理解。 2、指导和促使学生通过各种途径对C语言相关技术内容进行拓展和深入,增强自学能力、软件开发能力等综合能力的培训。 二、综合实训题目:学生成绩管理系统 完成下列功能: 1、初始化:把50个学生的学号、姓名、性别、年龄、四科成绩以及平均成绩和总成绩放在一个结构体数组中,学生的学号、姓名、四科成绩由键盘输入,然后计算出平均成绩和总成绩放在结构体对应的域中。 2、插入:输入一个学生的记录,按学号的先后顺序插入该学生的全部内容。 3、排序:对所有学生按要求排序(1.学号 2.总成绩),并输出。 4、查找:输入一个学生的学号或姓名,找到该学生并输出该学生的全部内容。要求能查询多次。 5、删除:输入一个学生的学号或姓名,找到该学生并删除该学生的全部内容。 6、输出: 输出全部学生的记录。 7、main调用所有函数,实现全部函数功能。 三、设计要求: 1、掌握《C语言程序设计》有关的专业基础知识和程序设计的基本方法。 2、学会利用程序的三种基本结构:顺序结构、选择结构、循环结构解决不同的问题。 3、学会根据实际需求定义变量及类型。 4、掌握过程和函数的定义及调用方法。 5、学会程序调试的基本方法。 四、时间分配: 序课程设计内容 号 1 2 3 4 界面设计 模块设计 程序综合调试 设计报告 总计 时)2 12 6 计学时 非上机时间完成不 时间(学 备注 五、实训报告要求 1、封面 2、目录 3、实训报告内容: 第一章 需求分析 第二章 系统设计 结构图 数据类型 第三章 程序实现 代码 第四章 心得与不足 设计题目 C语言程序设计实训 专业班级 网络101 学生姓名 学号 06 指导教师 张青 起止日期 2012.5.28—2010.6.1 河南化工职业学院 #include main() { int i=9; while(i) { printf(“n1.插入学生信息n”); printf(“2.修改学生信息n”); printf(“3.查询学生信息n”); printf(“0.退出n”); printf(“请选择功能:”); scanf(“%dn”,&i); switch(i) {case 1:printf(“n1.插入学生信息n”);break; case 2:printf(“n2.修改学生信息n”);break; case 3:printf(“n3.查询学生信息n”);break; default:printf(“n输入有误,重新输入n”); } } } C语言上机实训 试题2 所属语言:C语言 试卷方案:C语言上机实训 试卷总分:100分 共有题型:3种 一、程序填空 共1题(共计30分)第1题(30.0分) 题号:470 /*------------------------【程序填空】 -------------------------- 功能:从两个数组中分别提取任意元素x[i],y[j],问|x[i]-y[j]| 的最小值是多少 ? ------------------------*/ #include /***********SPACE***********/ #define min(x, y) (【?】) x int min_distance(int x[], int y[], int m, int n){ int minimum = INT_MAX; int index_x = 0, index_y = 0; while(index_x < m && index_y < n) /***********SPACE***********/ if(【?】)x[index_x] >= y[index_y] { minimum = min(minimum, x[index_x]-y[index_y]); index_y++; } else { minimum = min(minimum, y[index_y]-x[index_x]); /***********SPACE***********/ 【?】index_x++; } return minimum; } #include int x[] = { 1, 3, 7, 11, 18}; int m = sizeof(x)/sizeof(int); int y[] = { 4, 5, 8, 13, 22}; int n = sizeof(y)/sizeof(int); int i, min_distance(int [], int [], int, int); printf(“nCompute Minimum Distance Between Two Sorted Arrays”); printf(“n====”); printf(“nnGiven Array #1 :”); for(i = 0;i < m;i++) printf(“%5d”, x[i]); printf(“nnGiven Array #2 :”); for(i = 0;i < n;i++) printf(“%5d”, y[i]); printf(“nnMinimum Distance = %d”, min_distance(x, y, m, n));} 答案: =======(答案1)======= x =======(答案2)======= x[index_x] >= y[index_y] =========或========= y[index_y]<=x[index_x] =======(答案3)======= index_x++ =========或========= index_x=index_x+1 =========或========= ++index_x 二、程序改错 共1题(共计30分)第1题(30.0分) 题号:26 /*----------------------- 【程序改错】 ------------------------- 功能:实现3行3列矩阵的转置,即行列互换。 -----------------------*/ #include int i,j,t; for(i=0;i for(j=0;j /**********FOUND**********/ scanf(“%d”,&a[i][j]); for(i=0;i { for(j=0;j printf(“%4d”,a[i][j]); printf(“n”); } for(i=0;i /**********FOUND**********/ for(j=0;j { /**********FOUND**********/ a[i][j]=t; a[i][j]=a[j][i]; /**********FOUND**********/ t=a[j][i]; } for(i=0;i { for(j=0;j printf(“%4d”,a[i][j]); printf(“n”); } } main(){ int b[3][3]; fun(b,3);} 答案: =======(答案1)======= scanf(“%d”,&a[i][j]);=========或========= scanf(“%d”,(*(a+i)+j)); =======(答案2)======= for(j=0;jj;j++)=========或========= for(j=0;j<=i;j++)=========或========= for(j=0;i>=j;j++)=========或========= for(j=i+1;j for(j=i;j =======(答案3)======= t=a[i][j]; =======(答案4)======= a[j][i]=t; 三、程序设计 共1题(共计40分)第1题(40.0分) 题号:341 /*-----------------【程序设计】 ------------------- 功能:删除所有值为y的元素。数组元素中的值和y的值由 主函数通过键盘输入。 -----------------*/ #include void fun(int bb[],int *n,int y){ /**********Program**********/ int i,j;for(i=0;i<*n;) { if(bb[i]==y) {for(j=i;j<*n;j++) bb[j]=bb[j+1]; *n=*n-1; } else i++; } /********** End **********/ } main(){ int aa[M],n,y,k; printf(“nPlease enter n:”);scanf(“%d”,&n); printf(“nEnter %d positive number:n”,n); for(k=0;k printf(“The original data is:n”); for(k=0;k printf(“nEnter a number to deletede:”);scanf(“%d”,&y); fun(aa,&n,y); printf(“The data after deleted %d:n”,y); for(k=0;k printf(“n”); wwjt();} void wwjt(){ FILE *IN,*OUT; int n; int i[10]; int o; IN=fopen(“in.dat”,“r”); if(IN==NULL) { printf(“Read FILE Error”); } OUT=fopen(“out.dat”,“w”); if(OUT==NULL) { printf(“Write FILE Error”); } for(n=0;n<10;n++) { fscanf(IN,“%d”,&i[n]); } fun(i,&n,3); for(o=0;o { fprintf(OUT,“%dn”,i[o]); } fclose(IN); fclose(OUT);} 答案:----------------------int i,j;for(i=0;i<*n;) { if(bb[i]==y) {for(j=i;j<*n;j++) bb[j]=bb[j+1]; *n=*n-1; } else i++; }---------------------- 试题1 所属语言:C语言 试卷方案:C语言上机实训 试卷总分:100分 共有题型:3种 一、程序填空 共1题(共计30分)第1题(30.0分) 题号:417 /*------------------------【程序填空】 -------------------------- 功能:利用全局变量计算长方体的体积及三个面的面积。 ------------------------*/ #include int v; /***********SPACE***********/ v=【?】; s1=a*b; /***********SPACE***********/ s2=【?】; s3=a*c; return v;} main(){ int v,l,w,h; printf(“ninput length,width and height: /***********SPACE***********/ scanf(”%d%d%d“,【?】,&w,&h); /***********SPACE***********/ v=【?】; printf(”v=%d s1=%d s2=%d s3=%dn“,v,s1,s2,s3);} 答案: ”); =======(答案1)======= a*b*c =========或========= a * b * c =======(答案2)======= b*c =========或========= b * c =======(答案3)======= &l =======(答案4)======= vs(l,w,h)=========或========= vs(l , w , h) 二、程序改错 共1题(共计30分)第1题(30.0分) 题号:392 /*----------------------- 【程序改错】 ------------------------- 功能:统计出若干个学生的平均成绩,最低分以及得最低分的人数。例如:输入10名学生的成绩分别为92,87,68,56,92,84,67,75,92,66,则输出平均成绩为77.9,最低高分为56,得最 低分的人数为1人。 -----------------------*/ #include float Min=0;int J=0;float fun(float array[],int n){ int i;float sum=0,ave; Min=array[0]; for(i=0;i { if(Min>array [i])Min=array [i]; /**********FOUND**********/ sum=+array [i]; } /**********FOUND**********/ ave=sumn; for(i=0;i /**********FOUND**********/ if(array [i]=Min)J++; return(ave);} main(){ float a[10],ave; int i=0; for(i=0;i<10;i++) scanf(“%f”,&a[i]); ave=fun(a,10); printf(“ave=%fn”,ave); printf(“min=%fn”,Min); printf(“Total:%dn”,J);} 答案: =======(答案1)======= sum+=array[i];=========或========= sum=sum+array [i]; =======(答案2)======= ave=sum/n; =======(答案3)======= if(array [i]==Min)J++; 三、程序设计 共1题(共计40分)第1题(40.0分) 题号:390 /*-----------------【程序设计】 ------------------- 功能:编写函数求1~100中奇数的平方和。 结果为166650.000000。 -----------------*/ #include float sum(int n){ /**********Program**********/ /********** End **********/ } main(){ printf(“sum=%fn”,sum(100)); wwjt();} void wwjt(){ FILE *IN,*OUT; int i; float o; IN=fopen(“in.dat”,“r”); if(IN==NULL) { printf(“Read FILE Error”); } OUT=fopen(“out.dat”,“w”); if(OUT==NULL) { printf(“Write FILE Error”); } for(j=0;j<5;j++) { fscanf(IN,“%d”,&i); o=sum(i); fprintf(OUT,“%fn”,o); } fclose(IN); fclose(OUT);} 答案:----------------------float s=0;int i;for(i=1;i<=n;i=i+2) s=s+i*i;return(s);---------------------- 试题3 所属语言:C语言 试卷方案:C语言上机实训 试卷总分:100分 共有题型:3种 一、程序填空 共1题(共计30分)第1题(30.0分) 题号:410 /*------------------------【程序填空】 -------------------------- 功能:有n个整数,使其前面各数顺序向后移m个位置,最后m个数 变成最前面的m个数 ------------------------*/ #include /***********SPACE***********/ move(【?】)int n,m,array[20];{ int *p,array_end; /***********SPACE***********/ array_end=*(【?】); for(p=array+n-1;p>array;p--) /***********SPACE***********/ *p=*(【?】); *array=array_end; m--; if(m>0)move(array,n,m);} main(){ int number[20],n,m,i; printf(“the total numbers is:”); scanf(“%d”,&n); printf(“back m:”); scanf(“%d”,&m); for(i=0;i scanf(“%d,”,&number[i]); scanf(“%d”,&number[n-1]); /***********SPACE***********/ move(【?】); for(i=0;i printf(“%d,”,number[i]); printf(“%d”,number[n-1]);} 答案: =======(答案1)======= array,n,m =======(答案2)======= array+n-1 =========或========= array + n-1 =======(答案3)======= p-1 =========或========= p-1 =======(答案4)======= number,n,m 二、程序改错 共1题(共计30分)第1题(30.0分) 题号:413 /*----------------------- 【程序改错】 ------------------------- 功能:读取7个数(1-50)的整数值,每读取一个值,程序打印 出该值个数的*。 -----------------------*/ #include int i,a,n=1; /**********FOUND**********/ while(n<7) { do { scanf(“%d”,&a); } /**********FOUND**********/ while(a<1&&a>50); /**********FOUND**********/ for(i=0;i<=a;i++) printf(“*”); printf(“n”); n++;} } 答案: =======(答案1)======= while(n<=7) =========或========= while(n<8) =======(答案2)======= while(a<1||a>50);=========或========= while(a>50||a<1); =======(答案3)======= for(i=1;i<=a;i++) 三、程序设计 共1题(共计40分)第1题(40.0分) 题号:337 /*-----------------【程序设计】 ------------------- 功能:将两个两位数的正整数a、b合并形成一个整数放在 c中。合并的方式是:将a数的十位和个位数依次放 在c数的百位和个位上,b数的十位和个位数依次放 在c数的十位和千位上。 例如:当a=45,b=12。调用该函数后,c=2415。 -----------------*/ #include void fun(int a, int b, long *c) { /**********Program**********/ /********** End **********/ } main() { int a,b;long c; printf(“input a, b:”); scanf(“%d%d”, &a, &b); fun(a, b, &c); printf(“The result is: %ldn”, c); wwjt(); } void wwjt() { FILE *rf, *wf; int i, a,b;long c; rf = fopen(“in.dat”, “r”); wf = fopen(“out.dat”,“w”); for(i = 0;i < 10;i++) { fscanf(rf, “%d,%d”, &a, &b); fun(a, b, &c); fprintf(wf, “a=%d,b=%d,c=%ldn”, a, b, c); } fclose(rf); fclose(wf); } 答案:----------------------*c=a/10*100+a%10+b/10*10+b%10*1000;----------------------第二篇:c语言 学生信息管理系统(线性表版)
第三篇:代理商信息管理系统 c语言
第四篇:c语言综合实训
第五篇:C语言上机实训