c语言课程设计 机房机位预定系统 绝对正确,附源代码知识讲解
C语言机房机位预约系统课设(附源码)
C语言机房机位预约系统课设项目说明本系统基于C语言开发,适用于刚入门的C语言新手项目课设,开发软件采用VC++6.0开发,VS,DEV C++等均可运行。
(书生)项目运行截图代码界面截图完整源码#include<stdio.h>#include<stdlib.h>#include<string.h>#include<time.h>int timeone();/*机位、顾客信息结构体*/typedef struct PCInfo{int State[6]; //机位状态,2小时为一个时间段,8时到20时共6个时间段,0表示有空位,1表示无空位char name[20]; //各时间段运行顾客char sex[30];char tel[20];int year;int month;int day;int start_Time;int end_Time;}PCInfo;PCInfo info[100][100]; //存放100天,20台机位信息int Month[] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; /*数组定义每月天数*/int date[12][31]; /*定义日期和机位信息数组*//******************************空白函数模块*****************************/void s_line(int n) /*空行*/{int i;for (i = 1; i <= n; i++)printf("\n");}void space(int n) /*空白*/{int i;for (i = 1; i <= n; i++){printf(" ");}}/******************************清空机位信息模块*****************************/void Empty(){int i,j,k,a;for (i = 0; i <=20 ; i++) /*此循环作用是将0赋给机位状态*/{for (a = 0; a <= 20; a++){for (j = 0; j <= 6; j++){info[i][a].State[j] = 0;}}}for (j = 0; j <= 12; j++) /*此循环作用是将0赋给日期*/{for (k = 0; k <= 31; k++){date[j][k] = 0;}}}/******************************查询机位信息模块*****************************/void Query(){int year, month, day, start_Time, end_Time, time,a=1;int n = 0;int i;while (1){printf("\t\t ********************此处你可以输入时间来查看20个计算机的机位信息********************\n\n");printf("\t\t\t\t 请输入您想要查询的日期时间:(例如:2016/7/22/8-10表示)\n\n");scanf("%d/%d/%d/%d-%d", &year, &month, &day, &start_Time, &end_Time); /*输入查询时间*/if ((start_Time - 8) / 2 >= 0 && (start_Time - 8) / 2 <= 6){time = (start_Time - 8) / 2;}else{printf("输入时间段错误!\n");system("pause");return;}if (month < 1 || month > 12 || day < 0 || day > Month[month])/*如果输入时间不对就回出错,显示出错信息并且给出提示*/ {printf(" 输入错误!\n");printf(" 请选择输入指令:1.重新输入 2.返回菜单\n");scanf("%d", &n);if (n == 2) { break; }if (n == 1){break;}}else break; //未出错则跳出循环,继续执行后面程序}if (n == 2) return;printf("当前您要查询第几次预约的机位信息?(相同日期视为一次)\n\n");scanf("%d", &a);for (i = 1; i <= 20; i++) /*此循环的作用是判断是否有空的机位*/{if (date[month][day] == 1 && info[i][a].State[time] == 1)printf("\t\t\t\t 第%d 号计算机在这段时间已经被预定. \n\n", i);elseprintf("\t\t\t\t 第%d 号计算机在这段时间内没有被预定. \n\n", i);}system("pause"); /*系统暂停,按任意键继续*/}/******************************机位预定模块*****************************/void book_computer() /*此函数的作用是预定机位*/{int year, month, day, start_Time, end_Time, time;int b = 0, m = 0;int n = 0, i = 0, j, k, s,t;while (1){printf("\t\t********************此处你可以输入(年/月/日/XX-XX时间段)来查看是否有空位计算机********************\n\n");printf("\t\t如果有空闲机位将会自动预约,如果无空位,您可以选择最近时间段空位计算机进行预约!\n\n");printf("\t\t\t\t 请输入您想要预约的日期时间:(例如:2016/7/22/8-10表示)\n");scanf("%d/%d/%d/%d-%d",&year,&month, &day, &start_Time, &end_Time);/*输入查询时间*/if ((start_Time - 8) / 2 >= 0 && (start_Time - 8) / 2 <= 6){time = (start_Time - 8) / 2;}else{printf(" 输入时间段错误!\n");}if (month < 1 || month > 12 || day < 0 || day > Month[month])/*检验查询时间是否出错,并给出提示信息*/{printf(" 输入错误!\n");printf(" 请选择输入指令:1.重新输入 2.返回菜单\n");scanf("%d", &n);if (n == 2) break;}else break; //未出错则跳出循环,继续执行后面程序}if (n == 2) return;int a=0;s = timeone(); //该函数负责将不同时间段信息放置在二维数组结构体的不同列printf(" 请选择预约模式:\n");printf(" 1.按顺序预约 2.选择编号预约\n");scanf("%d", &a);if (a == 1) //顺序预约模块{for (i = 1; i <= 20; i++){if (date[month][day] == 0 || info[i][s].State[time] == 0){date[month][day] = 1;info[i][s].State[time] = 1;printf("\t\t ==================第%d 号计算机已经成功预约!==================\n ", i);printf("\t\t ================您可以在预约的时间段内使用计算机!============= \n \n ");printf("\t\t 本次为机位预约模拟系统第%d次预约(不同时期).请留意次数. \n", s);system("pause");return; //有一个符合条件的计算机,则return跳出该函数}}printf("您查询的时间段内无空闲机位!\n\n");printf("是否仍在非空闲时间段内使用电脑:\n\n");printf("1.是(加入等待队列)\n");printf("2.否(查找临近的空位计算机)\n");scanf("%d", &n);if (n == 1) /*如果加入等待列表,就输入相关的姓名,性别,电话和机位号*/{printf("请输入您想要等待的机位号::\n\n");scanf("%d", &m);printf("请输入您的姓名:\n\n");scanf("%s", info[m][s].name, 20);printf("请输入您的性别:(男或女)\n\n");scanf("%s", info[m][s].sex, 30);printf("请输入您的电话号码:\n\n");scanf("%s", info[m][s].tel, 20);info[m][s].year = year;info[m][s].month = month;info[m][s].day = day;info[m][s].start_Time = start_Time;info[m][s].end_Time = end_Time;printf("您已经成功加入等待队列......\n");system("pause");return;}/*通过四层嵌套循环寻找顺次向后推时间段内空机位信息*/for (i = month; i <= 12; i++) //月份{for (j = day; j <= Month[i]; j++) //日期{for (k = 1; k <= 6; k++) //0-6时间段{for (m= 1; m < 20; m++) //1-20号机器{if (date[i][j] == 0 || info[m][s].State[time] == 0){printf("你可以预约到的最近时间段的计算机:第%d 号计算机%d年%d月%d日%d时-%d时\n", s, year, i, j, (2 * k + 6), (2 * k + 8));printf(" 1.预约第%d 号计算机的该段时间\n", s);printf(" 2.不预约并退出\n");printf(" 请输入1&2进行选择: \n");scanf("%d", &n);if (n == 1){printf("\t\t ==================第%d 号计算机已经成功预约!==================\n ", m);printf("\t\t ================您可以在预约的时间段内使用计算机!============= \n \n ");printf("\t\t 本次为机位预约模拟系统第%d次预约(不同时期).请留意次数. \n", s);date[i][j] = 1; /*将机位状态调整为1*/info[m][s].State[time] = 1;}system("pause"); /*系统暂停,按任意键继续*/return;}}}}}}if (a == 2) /*选择编号进行预约*/{printf("请输入您要预约的计算机机位号:\n");scanf("%d", &i);if (date[month][day] == 0 || info[i][s].State[time] == 0){date[month][day] = 1;info[i][s].State[time] = 1;printf("\t\t ==================第%d 号计算机已经成功预约!==================\n ", i);printf("\t\t ================您可以在预约的时间段内使用计算机!============= \n \n ");printf("\t\t 本次为机位预约模拟系统第%d次预约(不同时期).请留意次数. \n", s);system("pause");}else{printf("第%d号机位已经被他人预约!",i); /*重复之前等待信息载入代码*/printf("是否仍在非空闲时间段内使用电脑:\n");printf("1.是(加入等待队列)\n");printf("2.否(查找临近的空位计算机)\n");scanf("%d", &n);if (n == 1) /*如果预定机位,就输入相关的姓名,性别,时间段*/{printf("请输入您想要等待的机位号::\n\n");scanf("%d", &b);printf("请输入您的姓名:\n\n");scanf("%s", info[b][s].name,30);printf("请输入您的性别:(男或女)\n\n");scanf("%s", info[b][s].sex, 30);printf("请输入您的电话号码:\n\n");scanf("%s", info[b][s].tel, 20);info[b][s].year = year;info[b][s].month = month;info[b][s].day = day;info[b][s].start_Time = start_Time;info[b][s].end_Time = end_Time;printf("您已经成功加入等待队列......\n");system("pause");return;}for (i = month; i <= 12; i++) //月份{for (j = day; j <= Month[i]; j++) //日期{for (k = 1; k <= 6; k++) //0-6时间段{for (t = 1; t < 20; t++) //1-20号机器{if (date[i][j] == 0 || info[t][s].State[time] == 0){printf("你可以预约到的最近时间段的计算机:第%d号计算机%d年%d月%d日%d时-%d时\n\n", t, year, i, j, (2 * k + 6), (2 * k + 8));printf(" 1.预约第%d 号计算机的该段时间\n\n", t);printf(" 2.不预约并退出\n\n");printf(" 请输入1&2进行选择: \n\n");scanf("%d", &n);if (n == 1){printf("****************第%d 号计算机已经成功预约!**************** \n ", t);printf("***************您可以在该时间段内使用计算机!************** \n ");date[i][j] = 1;info[t][s].State[time] = 1;}system("pause");return;}}}}}}}}/******************************取消预约模块*****************************/void book_exit() /*此函数的作用是退出预定*/ {int year,month, day, start_Time, end_Time,time,s=0;int n = 0;while (1){printf("\n在此处您可以取消预约已预订的计算机\n");system("pause");printf("\n请输入您想要取消预约的日期时间:(例如:2016/7/22/8-10表示)\n");scanf("%d/%d/%d/%d-%d", &year,&month, &day, &start_Time, &end_Time);if ((start_Time - 8) / 2 >= 0 && (start_Time - 8) / 2 <= 6){time = (start_Time - 8) / 2;}else{printf("\n输入时间段错误!\n");system("pause");return;}if (month < 1 || month > 12 || day < 0 || day > Month[month]){printf(" 输入错误!\n");printf(" 请选择输入指令:1.重新输入 2.返回菜单\n");scanf("%d", &n);if (n == 2) break;}else break;}if (n == 2) return;printf("请输入您想要取消预约的计算机编号:.\n");scanf("%d", &n);printf("您要取消预约第几次预约的计算机机位:.\n");scanf("%d", &s);if (info[n][s].State[time] == 1){info[n][s].State[time] = 0;printf("第%d号机位取消预约成功!\n",n);}else{printf("在该段时间内您没有预约任何编号的计算机!\n");}system("pause");}/******************************查询等待信息模块*****************************/void Look_wait() /*此函数的作用是查询等待机位的人,并按序显示*/{int m;int year, month, day, start_Time, end_Time,s;printf("请输入您想要查询的日期时间:(例如:2016/7/22/8-10表示)\n\n");scanf("%d/%d/%d/%d-%d", &year, &month, &day, &start_Time, &end_Time);printf("请输入您要查询等待信息的机位号:\n\n");scanf("%d", &m);printf("正在查询,请稍候~\n\n");printf("第%d号计算机:\n\n", m);printf(" 您准备查找第几次预约的信息?\n\n ");scanf("%d", &s);printf("姓名:%s\n\n", info[m][s].name);printf("性别:%s\n\n", info[m][s].sex);printf("联系方式:%s\n\n", info[m][s].tel);printf("该成员于%d年%d月%d日加入本台计算机的等待队列\n\n", info[m][s].year, info[m][s].month, info[m][s].day);system("pause");return;}/******************************预约次数(不同时期)判别模块*****************************/int timeone() /*为了便于对不同预约时间相同机位信息判别加设*/ {int n=0,k;int s = 1;printf("如果在本系统首次预约请选择1 ,再次预约请选择2\n\n");scanf("%d", &n);if (n == 1){return s;}if (n == 2){int i=0;printf("预约日期与前几次是否相同? 1.相同 2.不同\n\n");scanf("%d",& i);if (i == 1){s = 0;printf("预约日期与第几次相同?\n");scanf("%d", &k);s = s + k;return s;}if (i == 2){s = 0;printf("本次为第几次预约(不同时期)?\n");scanf("%d", &k);s = s + k;printf("本次为机位预约模拟系统第%d次预约(不同时期).请留意次数. \n",s);return s;}}}/**********************************主函数模块*************************************/main(){Empty();int num;while (1){system("cls"); /* 清除文本模式窗口*/s_line(4);space(40);printf("********************主菜单********************\n"); /*使用空行函数排版*/s_line(2);space(55);printf("1.查询机位信息\n");s_line(1);space(55);printf("2.预约机位\n");s_line(1);space(55);printf("3.取消机位预约\n");s_line(1);space(55);printf("4.查询等待人员信息\n");s_line(1);space(55);printf("5.退出系统\n");s_line(2);space(40);printf("********************************************\n\n");printf("请输入1~5进行功能操作: \n");scanf("%d", &num); /*输入数字进行相应的函数的调用*/if (num == 5) break;switch (num){case 1:Query();break;case 2:book_computer();break;case 3:book_exit();break;case 4:Look_wait();break;default:printf("输入错误!\n");system("pause");exit(0);}}}。
c语言课程设计--机房机位预定系统
c语言课程设计--机房机位预定系统1 设计目的机房机位预定系统2 任务概述20台机器,编号1到20,从早八点到晚八点。
两小时一个时间段,每次可预定一个时间段。
功能要求:(1)系统以菜单方式工作(2)查询,根据输入时间,输出机位信息。
(3)机位预定,根据输入的时间查询是否有空机位,若有则预约,若无则提供最近的时间段,另:若用户在非空时间上机,则将用户信息列入等待列表。
(4)退出预定,根据输入的时间,机器号撤销该事件的预定!(5)查询是否有等待信息,若有则提供最优解决方案(等待时间尽量短),若无则显示提示信息。
.........3 模块划分4 主要函数说明及其N-S图1. 主函数:int main(){Menu(); /*当前状态函数*/}void Menu() /*主界面*/{int n,w;do{puts("\t\t****************机房机位预约系统*******************\n");puts("\t\t*************************菜单***************************\n");puts("\t\t\t 1.查询某时间段机位状态"); /*查询某时间段机位状态*/puts("\t\t\t 2.预定空机位"); /*预定空机位*/puts("\t\t\t 3.取消预订"); /*取消预订*/puts("\t\t\t 4.查询等待信息"); /*查询等待信息*/puts("\t\t\t 5.退出"); /*退出*/puts("\t\t****************************************** **************\n");printf("选择菜单号(1-5):");scanf("%d",&n);if(n<1||n>5){w=1;getchar();}elsew=0;}while(w==1);switch(n){case 1:Situation();break;case 2:Book();break;case 3:Cancel();break;case 4:SearchWaiting();break;case 5:exit(0);break;}getch();}2.机位查询:void Situation(){int time;printf("输在(8-20)范围内的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t时间输入错误!\n");printf("输入在(8-20)范围内的时间:");scanf("%d",&time);}detail(time); /*函数调用*/getchar();Menu();}3.机位预定:void Book(){int time,i=0,x,y;FILE *fp;char c;printf("在(8-20)时间范围内输入你想要预定的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t时间输入错误!\n");printf("\t在(8-20)时间范围内输入你想要预定的时间:");scanf("%d",&time);}detail(time); /*函数调用*/if(sum[T]>0){ if((fp=fopen("waitlist.txt","a"))==NUL L){printf("\n无法打开文件!\n");exit(0);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");scanf("%s %s",wait[i].number,wait[i].teleph onenumber);for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp);/*向文本文档添加一个结构体单元*/printf("\t再次输入你想要预定的时间!\n");scanf("%d",&x);/*sum[T]--; / *预定后该时间段空机位数减1*//*computer[T][x]=1; / *预定后该机状态变为1*/printf("\t预订成功!\n");getchar();Menu();}else{printf("这是在这个时间段内未预定的电脑!\n");for(i=T+1;i<6;i++){ time=9+2*i;detail(time); /*函数调用*/if(sum[T]>0)printf("\tThe latest free time is %d,%d\n",2*i+8,2*i+10);break;}printf("\t你想要预定吗?:y/n?");scanf("%s",&c);getchar();if(c=='Y'||c=='y'){if((fp=fopen("waitlist.txt","r"))==NULL){printf("\n无法打开文件!\n");exit(0);}else{ printf("waitlist:number telephonenumber\n");for(i=0;!feof(fp);i++){fscanf(fp,"%s %s",&wait[i].number,&wait[i]. telephonenumber);}fclose(fp);}for(i=0;i<10;i++){ prione(i);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");if((fp=fopen("waitlist.txt","a"))==NULL){printf("\n无法打开文件!\n");exit(0);}scanf("%s %s",wait[i].number,wait[i].teleph onenumber);for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp); /*若等待,就用文件的方式列出当时的等待列表并提示输入你的等待序号和联系方式*/printf("再次输入电脑的序号!\n");scanf("%d",&y);sum[T]--;computer[T][y]=1;printf("\t好了,请等待我们的电话!\n");Menu();}else Menu();}}N4.取消预定:void Cancel(){int time,number;printf("在(8-20)时间范围内输入你已经预定的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t输入时间错误!\n");printf("\t在(8-20)时间范围内输入你已经预定的时间:");scanf("%d",&time);}else{printf("\t输入你预定的机号:");scanf("%d",&number);}detail(time);/* sum[T]++; / *预定后该时间段空机位数加1*//*computer[T][number]=0; / *预定后该机状态变为0*/printf("\t取消成功!\n");getchar();Menu();}5.查询等待信息:void SearchWaiting(){int time,i;FILE *fp;printf("\tInput time you want to search between(8-20):");scanf("%d",&time);if(time<8||time>20){printf("\tWrong time!\n");printf("\tInput time you want to search between(8-20):");scanf("%d",&time);}else;if((fp=fopen("waitlist.txt","r"))==NULL){printf("\nCannot open file!\n");exit(0);}else{ printf("waitlist:number telephonenumber\n");for(i=0;!feof(fp);i++){fscanf(fp,"%s %s",&wait[i].number,&wait[i]. telephonenumber);}fclose(fp);}for(i=0;i<10;i++){ prione(i);}Menu();}5 程序运行数据及其结果1.主菜单:2.机位查询:3.机位预定:4.查询等待信息:6 课程设计心得课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.随着科学技术发展的日新日异,当今计算机应用在生活中可以说得是无处不在。
c语言机房机位预定系统
课程设计说明书学院、系:专业:学生姓名:学号:设计题目:学生考勤系统起迄日期:指导教师:日期: 2017年5月11日1 设计目的模拟考勤过程,根据考勤评分给出考勤分数。
2 任务概述1>菜单界面:选择操作项目。
2>信息录入:输入学生身份信息与考勤次数,并存入文件。
3>修改功能:通过姓名或学号查找,对学生的考勤次数进行修改。
4>查询功能:通过姓名或学好查找,输出学生信息。
5>评分功能:设定标准考勤次数,按照考勤次数占标准考勤次数的百分比给分。
3 模块划分图1,模块划分图4 主要函数说明及其流程图main主函数:图2,主函数主函数:设计了初始界面,使程序的界面友好化。
给用户选择操作项目,让用户对程序的功能一目了然。
调用功能函数,完成设计目的。
图3,input()函数录入函数:通过使用循环体和判断语句,可实现重复输入学生数据和是否确定输入的功能。
使得用户操作起来更加自如。
图4,change()函数修改函数:通过学号和姓名两种方式可以查询到学生的信息,然后将考勤次数重新赋值并写入文件。
这样可以避免出现错误无法修改以至于重新输入的情况。
search()函数:图5,search()函数查询函数:通过学号和姓名两种方式可以选择查找方式,将文件的内容读出,可以看到学生的身份信息和修改后的考勤次数。
确定该生信息存在。
evaluate()函数:图6,evaluate()函数评分函数:输入标准考勤次数,将实际考勤次数占标准考勤次数的百分比作为最后分数。
5 程序运行数据及其结果姓名:张三学号:1性别:男考勤次数:5修改后考勤次数:10标准考勤次数:10考勤分数:1006 课程设计心得通过编写这次C语言课程设计,对C语言的基本语法,选择,循环等结构有了更深刻的认识。
深入地练习了函数的调用和文件的读写方法,熟悉了结构体的使用,和一些算法的运用。
在整个设计的过程中,遇到了很多问题。
当出现语法错误的时候,首先自己看书,看书上的语法和在例题中的应用,从而对该语法的记忆进一步加深。
C语言课程设计报告—机房机位预约模拟系统95372
程序设计报告C语言程序设计编程实践是学习C语言程序设计的一重要环节,为提高学生程序设计能力,通过课堂和上机实践练习使学生的程序设计能力上一台阶。
通过前四单元温顾而知新、庖丁解牛、举一反三、熟能生巧等过程的练习设计下面一个完整的程序1.题目要求设计机房机位预约模拟系统”要求:20台机器,从早8点到晚8点,每两个小时一个时间段。
需要实现功能:1,查询,根据输入时间,输出机位信息。
2,即为预定,根据输入的日期和时间段查询是否有空机位,若有则预约,若无则提供最近空机时间段。
另:若用户要求在非空时间上机,则将用户信息插入该时间段的等待列表.3,退出预定,根据输入的时间,撤销该时间的预定。
4,查询是否有等待的信息,若有则按顺序显示联系方式,若无则显示提示信息。
2需求分析根据题目要求在程序中需实现查询,预定,排队等功能的操作,所以需要建立相应的模块来实现;另外还需提供键盘式选择菜单实现功能,在运行时达到所要目的3总体设计整个系统可分为3个模块查询模块预定模块取消模块机房机位预约模拟< 系统查询模块预定模块取消模块___________ )详细设计主函数比较简洁,只提供输入、功能处理和输出部分的函数调用。
(开始显示一系列功能选择结束mai n(){int i;for(i=0;i<LENGTH;i++){TimeQueue[i].CNum=0;TimeQueue[i].first=NULL;TimeQueue[i].middle=NULL;TimeQueue[i].last=NULL;}while(1){printf("请输入序号!:\n");输入n ,判断m是否是0到6? N根据n 值调用各功能模块函数printf("1.查询预定的机位 2.查询空机位3•预定4.取消预定5.等待列表6.查询等待者列表0.退出\n");sea nf("%d",&i);switch(i){case 1:1 nq uir();break;case 2:i nq uir();break;case 3:book in g();break;case 4:ca ncel();break;case 5:wait in g();break;case 6:i nqu ir_wait in g();break;case 0:exit(0);default:pri ntf("error\ n");}}}void Inq uir(){int n;char Infor[10];struct node *Rem;printf(” 输入查询时间(24 hours 8~20 o'clock」nclude 8o'clock)\n"); sca nf("%d",&n);if(n >=8&&n <20){n=S( n);printf("请输入学号\n");sca nf("%s",l nfor);Rem=TimeQueue[ n].first;for(;Rem->n ext!=NULL;Rem=Rem->n ext)if(strcmp(Rem->data,l nfor)==0)break;if(Rem->locat!=0)prin tf("The computer nu mber is %d\n ”,Rem->locat);else printf("对不起•你依旧在等待列表中或者没有预定”);}else printf("错误,请再次输入.\n");}void inq uir(){int n;printf("输入想要查询的时间(24 hours 8~20o'clock,include 8 o'clock)\n"); sca nf("%d",&n);if(n >=8&&n <20){n=S( n);if(TimeQueue[ n].CNum<MAX)prin tf("There are %d empty computer!\n",MAX-TimeQueue[ n].CNum); else printf("对不起.没有空余机位\n");}else printf("错误,再次输入.\n"); }预定模块void book ing()int n;char In for[10];struct node *Rem;struct node *p;printf("输入想要预定的时间\n");sca nf("%d",&n);if(n >=8&&n< 20){ n=S( n);if(TimeQueue[ n].CNum<MAX){ printf("请输入你的学号\n");sca nf("%s",I nfor);if(TimeQueue[ n].first==NULL){Rem=(struct node *)malloc(sizeof(struct no de)); Rem->locat=1; strcpy(Rem->data,l nfor);Rem-> next=NULL;TimeQueue [n ].first=Rem;TimeQueue[ n].last=Rem;TimeQueue[ n].CNum++;printf("成功预定\n");}else{Rem=(struct node *)malloc(sizeof(struct no de)); strcpy(Rem->data,I nfor);Rem-> next=NULL;p=TimeQueue[ n].last;Rem->locat=TimeQueue[ n].CNum+1;prin tf("%d",Rem->locat);TimeQueue[ n].last=Rem;p->n ext=Rem;TimeQueue[ n].CNum++;printf("成功预定\n");}}else printf("没有空余机位!");}else printf(”错误•请再次输入.\n");}void wait in g(){int n;char Infor[10];struct node *Rem;struct node *p;printf("请输入想要排队的时间\n");sca nf("%d",&n);if(n >=8&&n <20){n=S( n);if(TimeQueue[ n].CNum>=MAX){printf("请输入你的学号\n”);scanf("%s",lnfor );if((TimeQueue[ n].CNum)==MAX){Rem=(struct node *)malloc(sizeof(struct no de)); strcpy(Rem->data,l nfor);Rem-> next=NULL;Rem->locat=0;p=TimeQueue[ n].last;TimeQueue[ n].last=Rem;p->n ext=Rem;TimeQueue[ n].middle=Rem;下载可编辑TimeQueue[ n].CNum++;printf("成功排队\n");}else{Rem=(struct node *)malloc(sizeof(struct no de));strcpy(Rem->data,I nfor);Rem-> next=NULL;Rem->locat=0;p=TimeQueue[ n].last;TimeQueue[ n].last=Rem;p->n ext=Rem;TimeQueue[ n].CNum++;printf("成功排队\n");}}下载可编辑else printf(”有空余机位,无须等待\n");}else printf("错误•再次输入.\n");}取消模void can cel(){int n;int i;char In for[10]; struct node *Rem; struct node *q;struct node *p;printf("请输入预定的时间\n");sea nf("%d",&n);if(n >=8&&n <20){prin tf("Please in put your No.!\n");sca nf("%s",l nfor);n=S( n);Rem=TimeQueue[ n].first;q=Rem;for(i=1;;q=Rem,Rem=Rem-> next,i++)if(strcmp(Rem->data,I nfor)==0)break; if(i>MAX){ if(Rem-> next==NULL){q-> next=NULL;TimeQueue [n ].last=q;free(Rem);TimeQueue[ n].CNum--;prin tf("Succeed to out the queue!\n");}else{q->n ext=Rem->n ext;free(Rem);TimeQueue[ n].CNum--;prin tf("Succeed to out the queue!' n");}}else{if(TimeQueue[ n].CNum>MAX){TimeQueue [n ].middle->locat=Rem->locat; TimeQueue[ n].middle=TimeQueue[ n].middle-> next; }if(i==1) TimeQueue [n ].first=Rem-> next;else q->n ext=Rem->n ext;free(Rem);TimeQueue[ n].CNum--;printf(”成功取消预定!\n");附录源代码:#include<stdio.h>#in clude<stdlib.h>#in clude<stri ng.h>#defi ne LENGTH 6#defi ne MAX 20#defi ne S(r) (r-8)/2#defi ne NULL 0struct no de{in t locat;char data[10];struct node *n ext;};struct node *head;struct cell{int CNum;struct node *first; struct node *middle; struct node *last;}TimeQueue[LENGTH];void Inq uir(){int n;char Infor[10];struct node *Rem;printf(” 输入查询时间(24 hours 8~20 o'clock」nclude 8o'clock)\n"); sca nf("%d",&n);if(n >=8&&n <20){n=S( n);printf("请输入学号\n");sca nf("%s",l nfor);Rem=TimeQueue[ n].first;for(;Rem->n ext!=NULL;Rem=Rem->n ext)if(strcmp(Rem->data,I nfor)==0)break;if(Rem->locat!=0)prin tf("The computer nu mber is %d\n ”,Rem->locat);else printf("对不起•你依旧在等待列表中或者没有预定”);}else printf("错误,请再次输入.\n");}void inq uir(){int n;printf("输入想要查询的时间(24 hours 8~20o'clock,include 8 o'clock)\n");sea nf("%d",&n);if(n >=8&&n <20){n=S( n);if(TimeQueue[ n].CNum<MAX)prin tf("There are %d empty computer!' n",MAX-TimeQueue[ n].CNum); else printf("对不起.没有空余机位\n");}else printf("错误,再次输入.\n");}void book in g(){int n;char In for[10];struct node *Rem;struct node *p;printf("输入想要预定的时间\n");sca nf("%d",&n);if(n >=8&&n <20){if(TimeQueue[ n].CNum<MAX){n=S( n);if(TimeQueue[ n].CNum<MAX){printf("请输入你的学号\n”);sea nf("%s",l nfor);if(TimeQueue[ n].first==NULL){Rem=(struet node *)malloc(sizeof(struct no de));Rem->locat=1; strcpy(Rem->data,l nfor);Rem-> next=NULL;TimeQueue [n ].first=Rem;TimeQueue[ n].last=Rem;TimeQueue[ n].CNum++;printf("成功预定\n");}else{Rem=(struct node *)malloc(sizeof(struct no de)); strcpy(Rem->data,I nfor); Rem-> next=NULL;p=TimeQueue[ n].last;Rem->locat=TimeQueue[ n].CNum+1;prin tf("%d",Rem->locat);TimeQueue[ n].last=Rem;p->n ext=Rem;下载可编辑TimeQueue[ n].CNum++;printf(” 成功预定\n");}}else printf("没有空余机位!");}else printf("错误.请再次输入.\n");}void wait in g(){int n;char Infor[10];struct node *Rem;struct node *p;printf("请输入想要排队的时间\n");sca nf("%d",&n);if(n >=8&&n <20){n=S( n);if(TimeQueue[ n].CNum>=MAX){printf("请输入你的学号\n”);sca nf("%s",l nfor);下载可编辑if((TimeQueue[ n].CNum)==MAX){Rem=(struct node *)malloc(sizeof(struct no de)); strcpy(Rem->data,l nfor); Rem-> next=NULL;Rem->locat=0;p=TimeQueue[ n].last;TimeQueue[ n].last=Rem;p->n ext=Rem;TimeQueue[ n].middle=Rem;TimeQueue[ n].CNum++;printf("成功排队\n");}else{Rem=(struct node *)malloc(sizeof(struct no de)); strcpy(Rem->data,I nfor); Rem-> next=NULL;Rem->locat=0;p=TimeQueue[ n].last;TimeQueue[ n].last=Rem;p->n ext=Rem;TimeQueue[ n].CNum++;下载可编辑prin tf("Please in put your No.!\n"); .专业.整理.printf (” 成功排队 \n");}else printf ("有空余机位,无须等待\n");}else printf ("错误•再次输入.\n");void can cel(){int n;int i;char In for[10];struct node *Rem;struct node *q;struct node *p;printf("请输入预定的时间\n ”); sca nf("%d",&n);if(n >=8&&n <20){ sca nf("%s",l nfor);n=S( n);Rem=TimeQueue[ n].first;q=Rem;下载可编辑for(i=1;;q=Rem,Rem=Rem-> next,i++) if(strcmp(Rem->data,l nfor)==0)break; if(i>MAX){if(Rem-> next==NULL){q-> next=NULL;TimeQueue [n ].last=q;free(Rem);TimeQueue[ n].CNum--;prin tf("Succeed to out the queue!' n");}else{q->n ext=Rem->n ext;free(Rem);TimeQueue[ n].CNum--;prin tf("Succeed to out the queue!' n");}}else{if(TimeQueue[ n].CNum>MAX){TimeQueue [n ].middle->locat=Rem->locat; TimeQueue[ n].middle=TimeQueue[ n].middle-> next; } if(i==1) TimeQueue[n].first=Rem->next;else q->n ext=Rem->n ext;free(Rem);TimeQueue[ n].CNum--;printf(”成功取消预定!\n");}}else printf("错误,请再次输入.\n");}void inqu ir_wait in g(){int n;struct node *q;printf("查询其他等待者的预定时间\n");sca nf("%d",&n);if(n >=8&&n <20){n=S( n);if(TimeQueue[ n].CNum>MAX){printf("等待列表are:\n”);q=TimeQueue[ n].middle;for(;q->n ext!=NULL;q=q_>n ext) prin tf("%s\n",q_>data); prin tf("%s\n",TimeQueue[ n] .last->data);}else printf("这个时间段没有预定者\n");}else printf("错误。
c语言机票预订系统课程设计
c语言机票预订系统课程设计一、课程目标知识目标:1. 让学生掌握C语言中结构体、数组、函数等基本知识点的综合应用;2. 让学生理解并掌握C语言中文件操作的基本方法;3. 让学生掌握C语言实现机票预订系统的基本原理和步骤。
技能目标:1. 培养学生运用C语言解决实际问题的能力,能独立完成机票预订系统的设计和编程;2. 培养学生分析问题、设计解决方案的能力,能针对具体需求进行模块划分和功能实现;3. 提高学生的团队协作能力,学会与他人合作共同完成一个项目。
情感态度价值观目标:1. 激发学生对计算机编程的兴趣和热情,培养良好的编程习惯;2. 培养学生面对问题勇于挑战、积极解决的态度,增强自信心;3. 通过团队合作,培养学生的集体荣誉感和责任感。
课程性质分析:本课程为C语言程序设计课程的实践环节,旨在让学生通过实际项目的开发,巩固所学知识,提高编程能力。
学生特点分析:学生已具备C语言基础知识,具有一定的编程能力,但缺乏实际项目经验,对综合运用知识解决实际问题的能力有待提高。
教学要求:1. 注重理论与实践相结合,引导学生将所学知识应用于实际项目中;2. 鼓励学生积极参与讨论,培养独立思考和解决问题的能力;3. 加强团队合作指导,提高学生的沟通能力和协作精神。
二、教学内容1. C语言基础知识回顾:结构体、数组、函数、指针、文件操作等;2. 机票预订系统需求分析:讲解系统功能需求,引导学生进行需求分析和模块划分;3. 系统设计:介绍C语言实现机票预订系统的基本原理,包括数据结构设计、模块设计等;4. 编程实现:- 数据结构设计:定义所需的结构体,如航班信息、用户信息等;- 功能模块实现:编写各功能模块的代码,如航班查询、预订、取消预订等;- 文件操作:实现数据的存储和读取,保证数据的持久化;5. 测试与优化:介绍测试方法,指导学生进行系统测试,发现问题并进行优化;6. 团队合作与项目展示:组织学生分组合作,完成整个项目,并进行项目展示和评价。
c课程设计机房管理系统(源代码)
课程设计报告课程名称:C课程设计班级:学号:姓名:完成日期:沈阳航空航天大学北方软件学院课设任务书专业名称:计算机网络技术设计题目:机房管理系统起止时间:2011年6月27日至2011 年7月8日问题描述通过开发一个机房管理系统,掌握与指针、数组(链表)有关的算法、函数的调用、结构体类型变量的定义和使用;文件打开、关闭、读、写等文件操作,提高对C 语言的实际运用能力。
基本要求机房管理系统实现功能:1.登录:根据菜单提示进行相应的的操作;2.机器信息文件的创建、增加、删除、修改;3.按型号,编号等对机器信息进行查询。
实现提示设计一个主菜单函数,通过菜单选择调用其他函数来实现相应的功能(switch语句)。
机器信息文件可包含编号,详细信息(主板,硬盘,cpu等信息)等项。
选作内容可根据主板,硬盘,cpu等机器信息进行分类统计机器数量。
学生姓名:学号:指导教师:年月日机房管理系统1概要设计用于机房管理,机房电脑的入库应在机房账目上加入电脑的入机房日期,电脑型号,数量,种类等,在电脑出库时应登记出库日期,数量种类等指标,手续经办人签名等。
并有机房盘点功能。
基本要求:入库登记功能出库登记功能机房盘点功能:机房中实际的存量电脑超出存储范围,或没有电脑的预警功能2详细设计主菜单说明struct product product[COUNT];//定义物品结构体数组void menu()//主菜单,应用于选择进行的操作{int choice,A;/*使主菜单循环*/do{printf("\n\n");printf("***********************************************************\n");printf("***********************欢迎进入****************************\n");printf("*********************机房管理系统**************************\n");printf("***********************主菜单******************************\n");printf("***********************************************************\n");printf("\t\t 1、电脑入库登记 \n");printf("\t\t 2、电脑出库登记\n");printf("\t\t 3、电脑库存查询\n");printf("\t\t 4、退出程序\n");printf("***********************************************************\n");printf("请选择所要执行的操作:");scanf("%d",&choice);结构体说明:1、struct product//定义物品的机构体{char name[SIZE];char model[SIZE];char kind[SIZE];char person[SIZE];int date;float inprice;int num;int innumber;int outnumber;int number;};查询菜单说明void Product_Search(){int select,B;for(;1;){system("cls");printf("\n\n");printf("***********************************************************\n");printf("*********************机房管理系统**************************\n");printf("**********************物品出查询***************************\n");printf("***********************************************************\n");printf("\t\t 1.按型号查询\n");printf("\t\t 2.按名称查询\n");printf("\t\t 3.按编号查询\n");printf("\t\t 4. 返回\n");printf("***********************************************************\n");printf("请选择所要执行的操作:");scanf("%d", &select);switch(select){case 1: searchbymodel();getch(); break;case 2: searchbyname();getch();break;case 3: searchbynum();getch();break;case 4: return menu();getch();break;default: printf("\n\n输入错误,请重新输入!!!!!\n");}}}指针、函数说明:3#define SIZE 30//定义字符串长度#define COUNT 100void menu();//菜单void Poduct_Enter();//定义货物入库函数void Product_Out();//货物出库void Product_Search();//货物查询void searchbymodel();//货物按型号查询void searchbyname();//货物按名字查询void searchbynum();//货物按编号查找void exit_system();//程序结束void save();//保存数据void open_out();//打开文件int i,p;2、struct product *p;//定义指针p=&product;3调试报告(1)忘记加分号,分号是C语句中不可缺少的一部分,语句末尾必须有分号,不该加分号的地方加了分号,后来经过调试改正了错误,另外,复合语句的花括号后不应再加分号,否则将会画蛇添足。
机房预订系统_代码
#include<stdio.h>#include<stdlib.h>#include<string.h>#include<conio.h>#include<iostream.h>#define MAX 2 //机房电脑总数#define S(r) (r-8)/2#define shijian(g) g*2+8typedef struct Cell{int CNum; //CNum表示这个时间段已预订的机器数struct Student *head;//这是表示这个时间段预订的机器的链表的第一个节点指针struct Student *last;}Cell;Cell TimeQueue_yuding[7][6];//七天,每天分为六个时间段,预订到电脑的队列Cell TimeQueue_paidui[7][6];//七天,每天分为六个时间段,排队队列typedef struct Student{// int times;//次数char number[10];//学号int locat;//机器号int day;//星期几int time;//时间struct Student *next;}Student;char *change(int n){char c[5];switch(n){case 0:strcpy(c,"日");break;case 1:strcpy(c,"一");break;case 2:strcpy(c,"二");break;case 3:strcpy(c,"三");break;case 4:strcpy(c,"四");break;case 5:strcpy(c,"五");break;case 6:strcpy(c,"六");break;}return c;}int Ture(int m,int n){if(m<0||m>6){printf("输入的时间(星期几)非法!请重新输入:\n");return 0;}else if(n<8||n>20){printf("您输入的时间(几点钟)不在上班时间内,请重新输入:\n");return 0;}elsereturn 1;}void waiting(int m,int n){char Infor[10];struct Student *Rem;printf("请输入你的学号\n");scanf("%s",Infor);if(TimeQueue_yuding[m][n].CNum+1<MAX){printf("此时间段有空余电脑,不需要排队!\n");return;}else if(TimeQueue_paidui[m][n].head==NULL){Rem=(Student *)malloc(sizeof(struct Student));strcpy(Rem->number,Infor);Rem->locat=1;Rem->day=m;Rem->time=n;Rem->next=NULL;TimeQueue_paidui[m][n].head=Rem;TimeQueue_paidui[m][n].last=Rem;TimeQueue_paidui[m][n].CNum++;printf("成功排队,在你之前有%d人在排队\n",Rem->locat-1);}else{Rem=(Student *)malloc(sizeof(struct Student));strcpy(Rem->number,Infor);Rem->locat=TimeQueue_yuding[m][n].CNum+1;Rem->day=m;Rem->time=n;Rem->next=NULL;TimeQueue_paidui[m][n].last->next=Rem;TimeQueue_paidui[m][n].last=Rem;TimeQueue_paidui[m][n].CNum++;printf("成功排队,在你之前有%d人在排队\n",TimeQueue_paidui[m][n].CNum-1);}}void inquir_waiting() //查询等待信息{Student *p;int m,n,t,k;char c1[5],c2[5];printf("查找全部请输入1;查找部分请输入2\n");scanf("%d",&t);switch(t){case 1:for(m=0;m<7;m++)for(n=0;n<6;n++){strcpy(c1,change(m));if(TimeQueue_yuding[m][n].CNum<MAX){printf("星期%s在%d到%d时间段内有%d台未被预订的电脑\n",c1,shijian(n),shijian(n)+2,MAX-TimeQueue_yuding[m][n].CNum);}else{printf("星期%s在%d到%d时间段内预订已经满,有%d人在排队\n",c1,shijian(n),shijian(n)+2,TimeQueue_paidui[m][n].CNum);printf("排队学生学号为:\n");p=TimeQueue_paidui[m][n].head;for(k=0;k<TimeQueue_paidui[m][n].CNum;k++){printf("%s\t",p->number );p=p->next ;}}}break;case 2:printf("输入想要查询的时间(0代表星期日;1代表星期一.......6代表星期六)\n");scanf("%d",&m);printf("输入想要查询的时间(24 hours 8~20o'clock,include 8 o'clock)\n");scanf("%d",&n);n=S(n);strcpy(c2,change(m));if(TimeQueue_yuding[m][n].CNum<MAX)printf("星期%s在%d到%d时间段有%d台未被预订的电脑\n",c2,shijian(n),shijian(n)+2,MAX-TimeQueue_yuding[m][n].CNum);elseprintf("星期%s在%d到%d时间段预订已经满,有%d人在排队\n",c2,shijian(n),shijian(n)+2,TimeQueue_paidui[m][n].CNum);break;}}void booking(int m,int n) //预订机位{int k,i,j;char c1,c3,c2,c4,c5[5],c6;char Infor[10];//学号Student *Rem;if(TimeQueue_yuding[m][n].CNum>=MAX){printf("此时间段没有空余电脑!你是否愿意在此时间段排队?,(输入y表排队,输入其他字符表退出)\n");printf("警告!如果你要排队,在没有足够人取消预订定的情况下,你可能不能预订到机位\n");k=m;for(i=k;i<7;i++)for(j=0;j<6;j++){if(TimeQueue_yuding[i][j].CNum<MAX){strcpy(c5,change(i));printf("星期%s在%d到%d时间段有%d个空机位,是否愿意更改预定时间,y/n?\n",c5,shijian(j),shijian(j)+2,MAX-TimeQueue_yuding[i][j].CNum);scanf("%c",&c2);scanf("%c",&c2);if(c2=='y')booking(i,j);if(TimeQueue_yuding[i][j].CNum<MAX){printf("还有%d台电脑,是否想继续在这个时间段预订,是输入y,退出输入t,否输入其他字符,/n?\n",MAX-TimeQueue_yuding[i][j].CNum);scanf("%c",&c6);scanf("%c",&c6);if(c6=='y')booking(i,j);if(c6=='t')return;}}printf("退出自动查询请输入y,否则输入其他字符:\n");scanf("%c",&c4);if(c4=='y')return;}scanf("%c",&c1);scanf("%c",&c1);if(c1=='y')waiting(m,n);else{printf("是否愿意查看预订时间表,y/n?\n");scanf("%c",&c3);scanf("%c",&c3);if(c3=='y')inquir_waiting();}}else{printf("请输入你的学号:\n");scanf("%s",Infor);if(TimeQueue_yuding[m][n].head==NULL){Rem=(Student *)malloc(sizeof(struct Student));strcpy(Rem->number,Infor);Rem->locat=1;Rem->day=m;Rem->time=n;Rem->next=NULL;TimeQueue_yuding[m][n].head=Rem;TimeQueue_yuding[m][n].last=Rem;TimeQueue_yuding[m][n].CNum++;printf("成功预定,机号为%d\n",TimeQueue_yuding[m][n].CNum);}else{Rem=(Student *)malloc(sizeof(struct Student));strcpy(Rem->number,Infor);Rem->locat=TimeQueue_yuding[m][n].CNum+1;Rem->day=m;Rem->time=n;Rem->next=NULL;TimeQueue_yuding[m][n].last->next=Rem;TimeQueue_yuding[m][n].last=Rem;TimeQueue_yuding[m][n].CNum++;printf("成功预定,机号为%d\n",Rem->locat);}}}void inquir(int m,int n)//查询空机位{char c1,c2,c3;if(TimeQueue_yuding[m][n].CNum<=MAX){printf("有%d个空机位,你是否想预订(输入y表预订,输入其他的字符表退出)\n",MAX-TimeQueue_yuding[m][n].CNum);scanf("%c",&c1); scanf("%c",&c1);if(c1=='y')booking(m,n);elsereturn;}else{printf("没有空机位,当前时间段有%d人在排队",TimeQueue_paidui[m][n].CNum);printf("你是否想在这个时间段排队?,(输入y表排队,输入其他字符表退出)\n");printf("警告!如果你要排队,在没有足够人取消预订定的情况下,你可能不能预订到机位\n");scanf("%d",&c2);scanf("%d",&c2);if(c2=='y')waiting(m,n);else{printf("是否愿意查看预订时间表,y/n?\n");scanf("%c",&c3);scanf("%c",&c3);if(c3=='y')inquir_waiting();}}}void Inquir() //查询已预订机位{char a[10],c[5];int m,n,t=0;Student *p;printf("请输入学号:\n");scanf("%s",a);for(m=0;m<7;m++)for(n=0;n<6;n++){p=TimeQueue_yuding[m][n].head;while(p!=NULL){if(!strcmp(p->number,a)){if(t==0){printf("预订的机位信息为:\n");t=1;}strcpy(c,change(p->day));printf("星期%s在%d到%d时间段\n",c,shijian(p->time),shijian(p->time));}p=p->next;}}if(t==0)printf("你没有成功预订的机位!\n");}void cancel(int m,int n) //取消预订{char c;int t=0,i;char Infor[10];struct Student *Rem;struct Student *q;loop:printf("Please input your Nobel!\n");scanf("%s",Infor);Rem=TimeQueue_yuding[m][n].head;q=Rem;for(i=1;Rem!=NULL;q=Rem,Rem=Rem->next,i++){if(!strcmp(Rem->number,Infor)){if(TimeQueue_paidui[Rem->day][Rem->time].head!=NULL){strcmp(Rem->number,TimeQueue_paidui[Rem->day][Rem->time].head->number);TimeQueue_paidui[Rem->day][Rem->time].head=TimeQueue_paidui[Rem->day][Rem->tim e].head->next;TimeQueue_paidui[Rem->day][Rem->time].CNum--;}else{TimeQueue_yuding[Rem->day][Rem->time].head=TimeQueue_yuding[Rem->day ][Rem->t ime].head->next;TimeQueue_yuding[Rem->day][Rem->time].CNum--;}t=1;}}if(t==0){printf("输入学号没有预订,是否再次输入:y/n?\n");scanf("%c",&c);scanf("%c",&c);if(c=='y')goto loop;return;}elseprintf("已取消预订!\n");}void newline(int n) /*此函数的作用是空行,若输入n就输出n行*/ {int i;for(i=1;i<=n;i++)printf("\n");}void space(int n) /*此函数的作用是留空白,输入n就输出n个空白*/ {int i;for(i=1;i<=n;i++){printf(" ");}}void main(){char c;int n,m,i,j,k;for(i=0;i<7;i++)for(j=0;j<6;j++){TimeQueue_paidui[i][j].CNum=0;TimeQueue_paidui[i][j].head=NULL;TimeQueue_paidui[i][j].last=NULL;TimeQueue_yuding[i][j].CNum=0;TimeQueue_yuding[i][j].head=NULL;TimeQueue_yuding[i][j].last=NULL;}while(1){space(20);printf("*********Menu*********\n");printf("1. 查询预定的机位\n2. 查询空机位\n3. 预定\n4. 取消预定\n5. 排队\n6. 查询等待者时间列表\n0. 退出\n");printf("请输入序号!:\n");space(20);printf("**********************\n");printf("请选择:\n");scanf("%d",&k);switch(k){case 1:Inquir();break;case 2:loop1:printf("输入想要查询的时间(0代表星期日;1代表星期一.......6代表星期六)\n");scanf("%d",&m);printf("输入想要查询的时间(24 hours 8~20o'clock,include 8 o'clock)\n");scanf("%d",&n);if(Ture(m,n)){n=S(n);inquir(m,n);}else{goto loop1;}break;case 3:loop2:printf("输入想要预订的时间(0代表星期日;1代表星期一.......6代表星期六)\n");scanf("%d",&m);printf("输入想要预订的时间(24 hours 8~20o'clock,include 8 o'clock)\n");scanf("%d",&n);if(Ture(m,n)){n=S(n);booking(m,n);}else{goto loop2;}break;case 4:loop3:printf("输入想要取消的时间(0代表星期日;1代表星期一.......6代表星期六)\n");scanf("%d",&m);printf("输入想要取消的时间(24 hours 8~20o'clock,include 8 o'clock)\n");scanf("%d",&n);if(Ture(m,n)){n=S(n);cancel(m,n);}elsegoto loop3;break;case 5:loop4:printf("输入想要排队的时间(0代表星期日;1代表星期一.......6代表星期六)\n");scanf("%d",&m);printf("输入想要排队的时间(24 hours 8~20o'clock,include 8 o'clock)\n");scanf("%d",&n);if(Ture(m,n)){n=S(n);waiting(m,n);;}elsegoto loop4;break;case 6:inquir_waiting();break;case 0:exit(0);default:printf("error\n");}printf("按Eeter继续:\n");scanf("%c",&c);scanf("%c",&c);system("cls");}}。
c语言课程设计--飞机订票系统
c语言课程设计–飞机订票系统一、教学目标本课程的教学目标是使学生掌握C语言编程的基本知识,能够使用C语言设计并实现一个简单的飞机订票系统。
具体分为以下三个部分:1.知识目标:学生需要掌握C语言的基本语法、数据类型、运算符、控制结构、函数等编程基础。
2.技能目标:学生能够运用C语言进行程序设计,解决实际问题,如设计飞机订票系统的各个功能模块。
3.情感态度价值观目标:培养学生对计算机科学的兴趣,提高学生解决问题的能力,培养学生的团队合作精神。
二、教学内容教学内容主要包括C语言的基本语法、数据类型、运算符、控制结构、函数等编程基础,以及如何使用C语言设计并实现一个简单的飞机订票系统。
具体安排如下:1.C语言基本语法和数据类型2.C语言运算符和控制结构3.C语言函数和数组4.C语言指针和字符串5.飞机订票系统的设计和实现三、教学方法为了达到课程目标,我们将采用以下教学方法:1.讲授法:用于讲解C语言的基本语法、数据类型、运算符、控制结构、函数等编程基础。
2.案例分析法:通过分析实际案例,让学生了解如何使用C语言设计并实现飞机订票系统。
3.实验法:让学生动手编写代码,实现飞机订票系统的各个功能模块。
四、教学资源为了支持教学内容和教学方法的实施,我们将准备以下教学资源:1.教材:《C程序设计语言》或《C语言程序设计》2.参考书:《C Primer Plus》或《C和指针》3.多媒体资料:教学PPT、视频教程4.实验设备:计算机、网络环境五、教学评估为了全面、客观地评估学生的学习成果,我们将采用以下评估方式:1.平时表现:通过课堂参与、提问、小组讨论等环节,评估学生的学习态度和积极性。
2.作业:布置课后编程作业,评估学生对C语言知识的掌握程度及编程能力。
3.考试:期末进行闭卷考试,评估学生对C语言编程基础知识的掌握情况。
4.项目实践:要求学生分组设计并实现一个简单的飞机订票系统,评估学生的实际编程能力和团队协作能力。
数据结构毕业课程设计(C语言版)飞机订票系统
(此文档为word格式,下载后您可任意编辑修改!)———C语言版课题:飞机订票系统和图的遍历的动态演示姓名:学号:班级:指导教师:订票系统1.需求分析任务:通过此系统可以实现如下功能:录入:可以录入航班情况(数据可以存储在一个数据文件中,数据结构、具体数据自定)查询:可以查询某个航线的情况(如,输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓);可以输入起飞抵达城市,查询飞机航班情况;订票:(订票情况可以存在一个数据文件中,结构自己设定)可以订票,如果该航班已经无票,可以提供相关可选择航班;退票:可退票,退票后修改相关数据文件;客户资料有姓名,证件号,订票数量及航班情况,订单要有编号。
修改航班信息:当航班信息改变可以修改航班数据文件要求:根据以上功能说明,设计航班信息,订票信息的存储结构,设计程序完成功能;2:主要设计思路:1)算法构造流程图:A:主菜单:B:各分块模板的构造流程图:3:功能函数设计:(1):订票系统主菜单函数menu_select()本函数主要构造系统的主菜单,系统需要实现很多功能,并且各个功能需要各自的函数支持,所以通过主菜单可以轻松的进入各个函数下实现各自的功能,故主菜单显得尤为重要。
其实就是通过键盘输入选择项,然后通过scanf接受,在通过swtich判断进入各个选择项。
(2):工作人员管理函数enter()&change()系统需要各个航班的详细信息,所以需要工作人员把信息输入系统里,以供乘客查询订票。
enter()函数的构造就是为了解决这个问题。
而有可能航班线路更改或由于天气等原因飞机的起飞时间发生了更改,故工作人员需要及时更改信息,所以需要构造change()函数。
(3):列出航班信息的函数list()乘客需要查询各个航班的信息,所以通过系统要能调出上面工作人员已经录入好的航班信息,所以构造本函数来实现这个功能。
(4)乘客具体查询函数search()本函数分两个分函数:search1()和search2(),它们分别实现乘客的按航班查询和按出发及抵达城市的两种查询方案。
c课程设计机房管理系统(源代码)
c课程设计机房管理系统(源代码)在进行C课程设计的过程中,设计一个机房管理系统是非常重要的一步。
机房管理系统的设计可以帮助学校或企业更好地管理机房资源,提高机房的利用率,保证机房的安全和稳定运行。
本文将从系统的需求分析、系统的设计、源代码实现等多个方面,详细介绍机房管理系统的设计过程。
一、系统需求分析机房管理系统的需求主要包括以下几个方面:1.1 机房资源管理:包括机房的基本信息管理(如机房编号、机房名称、机房位置等),机房设备的管理(如服务器、交换机等设备的信息管理)。
1.2 设备借还管理:包括设备借出、归还的记录管理,借出设备的有效期管理等。
1.3 机房安全管理:包括机房门禁的管理,设备的报警和监控等。
1.4 机房使用统计:包括机房的使用情况统计、设备的使用情况统计等。
1.5 系统权限管理:包括管理员权限管理、用户权限管理等。
二、系统设计2.1 数据库设计:根据系统需求,设计合适的数据库表结构来存储机房和设备的信息,设备借还记录等。
2.2 界面设计:设计用户友好的界面,方便用户进行相关操作,提高系统的易用性。
2.3 功能模块设计:根据系统需求,将系统功能进行模块化设计,并分别实现各个功能模块。
2.4 系统架构设计:设计合适的系统架构,包括前端界面与后端逻辑的交互方式,数据传输方式等。
三、源代码实现基于上述系统设计,我们使用C语言来实现机房管理系统的源代码。
以下是一个简单的示例:```c#include <stdio.h>// 定义机房结构体struct Classroom {int number;char name[100];char location[100];};// 定义设备结构体struct Device {int id;char name[100];char type[100];};// 定义设备借还记录结构体struct BorrowRecord {int deviceId;char borrower[100];char returnDate[100];};// 机房资源管理函数void manageClassroom() {// 实现机房资源管理功能的代码逻辑}// 设备借还管理函数void manageDeviceBorrow() {// 实现设备借还管理功能的代码逻辑}// 机房安全管理函数void manageClassroomSecurity() {// 实现机房安全管理功能的代码逻辑}// 机房使用统计函数void manageClassroomUsage() {// 实现机房使用统计功能的代码逻辑}// 系统权限管理函数void manageSystemPermission() {// 实现系统权限管理功能的代码逻辑}int main() {int choice;while(1) {printf("---- 机房管理系统 ----\n"); printf("1. 机房资源管理\n");printf("2. 设备借还管理\n");printf("3. 机房安全管理\n");printf("4. 机房使用统计\n");printf("5. 系统权限管理\n");printf("0. 退出系统\n");printf("请输入您的选择:");scanf("%d", &choice);switch(choice) {case 1:manageClassroom();break;case 2:manageDeviceBorrow();break;case 3:manageClassroomSecurity(); break;case 4:manageClassroomUsage(); break;case 5:manageSystemPermission();break;case 0:printf("感谢使用,再见!\n");return 0;default:printf("输入错误,请重新输入!\n");}}return 0;}```以上是一个简单的机房管理系统的C语言源代码示例,包含了机房资源管理、设备借还管理、机房安全管理、机房使用统计、系统权限管理等功能。
机房预定位系统
合肥学院计算机科学与技术系课程设计报告20 12 ~20 13 学年第一学期课程C语言课程设计课程设计题目机房机位预订系统学生姓名学号1204032015专业班级网络工程(2)班指导教师20 13 年 1 月目录一、课程设计目的 (2)二、课程设计名称及内容 (2)三、对任务和要求的分析 (2)四.详细设计及实现 (3)五、源代码 (18)六、程序测试 (24)七、总结 (25)一、课程设计目的将理论教学中涉及到的知识点贯穿起来,对不同的数据类型、程序控制结构、数据结构作一比较和总结,结合设计题目进行综合性应用,对所学知识达到融会贯通的程度。
通过课程设计,学生在下述各方面的能力应该得到锻炼:(1)进一步巩固、加深学生所学专业课程《C语言教程》的基本理论知识,理论联系实际,进一步培养学生综合分析问题,解决问题的能力。
(2)全面考核学生所掌握的基本理论知识及其实际业务能力,从而达到提高学生素质的最终目的。
(3)利用所学知识,开发小型应用系统,掌握运用C语言编写调试应用系统程序,训练独立开发应用系统,进行数据处理的综合能力。
(4)对于给定的设计题目,如何进行分析,理清思路,并给出相应的数学模型。
(5)掌握自顶而下的设计方法,将大问题进行模块化,领会结构化程序设计的方法。
(6)熟练掌握C语言的基本语法,灵活运用各种数据类型。
(7)进一步掌握在集成环境下如何调试程序(单步调试,设置断点、观察表达式,分块调试)和修改程序。
二、课程设计名称及内容课程设计名称:机房机位预定系统设计内容:设计一个机房机位预定系统,该系统要求对机房电脑机位进行管理和维护。
20台机器,从早八点到晚八点,每两个小时一个时间段.任务和要求:20台机器,编号1到20,从早八点到晚八点。
两小时一个时间段,每次可预定一个时间段。
设计一个机房机位预定系统,通过该系统实现对机房机位的预定管理。
三、对任务和要求的分析可行研究阶段的目标是:使工作人员从繁琐的机位管理工作中解放出来;提高工作质量,使供需双方都获得满意的结果;促进报表,提高工作效率。
C语言课程设计报告——飞机订票系统源代码
#include<stdio.h> //标准输入、输出头文件#include<string.h> //包含字符串函数处理头文件#include<process.h> //包含access函数的头文件#define N 9999 //定义最多的航班数#define PRINT "%d\t\t%s\t\t%s\t\t星期%s\t\t%d\n ",s[i].num,s[i].start,s[i].over,s[i].time,s[i].count //宏定义输出格式struct air //定义结构体数组{int num; //定义航班号char start[20]; //航班起始站char over[20]; //终点站char time[10]; //飞行时间int count; //机票数量}s[N];int i,m=0; //定义全局变量char ii[10];void add(); //函数声明增加航班信息函数void print(); //显示航班信息void search(); //查找航班信息void dingpiao(); //订票业务void tuipiao(); //退票void read(); //读取文件void save(); //保存文件void output(); //输出格式void paixu(); //航班排序void chushihua(); //系统初始化void build(); //建立数据文件void paixu1(); //按航班号从小到大排序void paixu2(); //从大到小void main() //主函数{int j;chushihua(); //系统初始化判断是否存在原始数据文件printf(" 欢迎使用飞机订票系统\n"); //打印出系统主界面do{printf("========================================================================= ======= ");printf("1.增加航班信息\n""\t2.浏览航班信息\n""\t\t3.查找航班信息(按航班号)\t\t╮(╯_╰)╭\n""\t\t\t4.航班排序(按航班号)\n""\t\t\t\t5.订票业务\n""\to(︶︿︶)o\t\t\t6.退票业务\n""\t\t\t\t\t\t0.退出\n");printf("===================================================================== =========== ");printf("请在0-6中选择以回车键结束:");scanf("%d",&j);switch(j){case 1: add(); //调用增加航班函数break;case 2:print(); //调用显示模块break;case 3:search(); //调用查找模块break;case 4:paixu(); //调用排序函数break;case 5:dingpiao(); //调用订票模块break;case 6:tuipiao(); //调用退票模块break;case 0: //退出系统save();printf("使用,再见!");break;}}while(j!=0); //判断是否调用其他函数}void chushihua() //定义系统初始化函数{if(access("hangban.dat",0)){build();}elseread();}void build() //定义建立数据文件函数{FILE *fp; //定义文件指针if((fp=fopen("hangban.dat","wb"))==NULL) //打开文件并判定是否出错{printf("创建文件失败! "); //打印出错提示getchar();return;}printf("请依次输入航班信息(以回车键结束):\n"); //打印提示信息printf("-------------------------------------------------------------------------- \n");for(i=0;i<N;i++){printf("请输入航班号: ");scanf("%d",&s[i].num); //输入航班号printf("请输入起始站: ");scanf("%s",s[i].start); //输入起始站printf("请输入终点站: ");scanf("%s",s[i].over); //输入终点站printf("请输入时间(星期几): ");scanf("%s",s[i].time); //输入时间printf("请输入机票数: ");scanf("%d",&s[i].count); //输入机票数fwrite(&s[i],sizeof(struct air),1,fp);m++;printf("添加完毕,是否继续添加?请键入y或n以回车键结束:");scanf("%s",ii);if(strcmp(ii,"y")!=0) //判断是否继续添加航班信息{fclose(fp); //关闭文件return;}}}void read() //定义读取文件函数{FILE *fp;if((fp=fopen("hangban.dat","r"))==NULL){printf("创建文件失败! ");getchar();return;}i=0;while(!feof(fp)){fread(&s[i],sizeof(struct air),1,fp); //逐块读取数据i++;m++; //计算存在航班数}m--;fclose(fp);}void save() //定义保存函数{FILE *fp;if((fp=fopen("hangban.dat","wb"))==NULL){printf("创建文件失败! ");getchar();return;}for(i=0;i<m;i++) //逐块保存数据fwrite(&s[i],sizeof(struct air),1,fp);fclose(fp);}void add() //定义增加航班信息函数{do{printf("请依次输入您要增加的航班信息(以回车键结束): \n"); //打印提示信息printf("-------------------------------------------------------------------------- \n");printf("请输入航班号: ");scanf("%d",&s[m].num); //读取航班号printf("请输入起始站: ");scanf("%s",s[m].start); //读取起始站printf("请输入终点站: ");scanf("%s",s[m].over); //读取终点站printf("请输入时间: ");scanf("%s",s[m].time); //读取时间printf("请输入机票数: ");scanf("%d",&s[m].count); //读取机票数m++;printf("添加完毕,是否继续添加?请键入y或n以回车键结束:");scanf("%s",ii);}while(!strcmp(ii,"y")); //判断是否继续添加}void output() //定义输出格式函数{printf("航班号\t\t起始站\t\t终点站\t\t时间\t\t机票数\n"); //信息标题for(i=0;i<m;i++)printf(PRINT);//打印出信息}void print() //定义显示航班信息函数{printf("\n目前我们有如下航班:\n");output(); //调用输出格式函数printf("\n请按回车键返回上层菜单");getchar();getchar();}void search() //定义查询函数{int n;do{printf("\n请输入航班号:");scanf("%d",&n); //输入查询的航班号for(i=0;i<m;i++){if(s[i].num==n) //按航班号判定输出条件{printf("\n您所查找的航班信息为:\n ");printf("航班号\t\t起始站\t\t终点站\t\t时间\t\t机票数\n\n");printf(PRINT); //显示信息printf("\n查询完毕,按回车键继续");getchar();getchar();return;}}printf("\n对不起,没有您需要的信息!\n ");printf("是否重新查找?请键入y或n以回车键结束");scanf("%s",ii);}while(!strcmp(ii,"y"));//判定是否重新查找}void dingpiao() //定义订票业务函数{int n;char a[10]="y";do{search(); //调用查询模块if(!strcmp(ii,"n")){printf("对不起!没有找到您所需要的航班,所以不能订票。
c语言课程设计机房机位预定系统绝对正确,附源代码解析
1设计目的机房机位预定系统2任务概述20台机器,编号1到20,从早八点到晚八点。
两小时一个时间段,每次可预定一个时间段。
功能要求:(1)系统以菜单方式工作(2)查询,根据输入时间,输出机位信息。
(3 )机位预定,根据输入的时间查询是否有空机位,若有则预约,若无则提供最近的时间段,另:若用户在非空时间上机,则将用户信息列入等待列表。
(4 )退出预定,根据输入的时间,机器号撤销该事件的预定!(5)查询是否有等待信息,若有则提供最优解决方案(等待时间尽量短),若无则显示提示信息。
3模块划分4主要函数说明及其N-S图1.主函数:int mai n(){Men u();}void Menu() {int n,w;do /*主界面*/puts("\t\t* *************** 机房机位预约系统***************** **\n"); puts("\t\t* ************************ ^菜************************** /*当前状态函数*/puts ("\t\t\t 1.查询某时间段机位状态 ”);/*查询某时间段机位状态 */ puts ("\t\t\t 2.预定空机位”); /*预定空机位*/ puts ("\t\t\t 3.取消预订");/*取消预订*/puts ("\t\t\t 4.查询等待信息”);/*查询等待信息*/puts ("\t\t\t 5.退出");/* 退出 */ printf("选择菜单号(1-5):");sca nf("%d",&n); if(n <1|| n>5) {w=1;getchar();} else w=0; }while(w==1); switch( n){case 1:Situati on( );break; case 2:Book();break;case 3:Ca ncel();break;case 4:SearchWaiti ng();break; case 5:exit(0);break; }getch();2. 机位查询:void Situati on() {int time;printf("输在(8-20)范围内的时间:"); sca nf("%d", &time); if(time<8||time>20)puts("\t\t****************************************************** **\n");{printf("\t时间输入错误!\n");printf("输入在(8-20)范围内的时间:”); sea nf("%d", &time);}detail(time); /*函数调用*/getchar();Men u();}3. 机位预定:void Book(){int time,i=0,x,y;FILE *fp;char c;printf("在(8-20)时间范围内输入你想要预定的时间:");sca nf("%d", &time);if(time<8||time>20){printf("\t时间输入错误!\n”);printf("\t在(8-20)时间范围内输入你想要预定的时间:");scan f("%d", &time);}detail(time); /*函数调用*/if(sum[T]>0){ if((fp=fope n( "waitlist.txt","a"))==NULL){printf("\n无法打开文件!\n");exit(0);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");sea nf("%s %s",wait[i]. nu mber,wait[i].telepho nenu mber); for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp);/*向文本文档添加一个结构体单元*/printf("\t再次输入你想要预定的时间!\n");sca nf("%d", &x);/*sum[T]--; / *预定后该时间段空机位数减1*//*computer[T][x]=1; / *预定后该机状态变为1*/printf("\t 预订成功!\n”);getchar();Me nu();}else{printf("这是在这个时间段内未预定的电脑!\n");for(i=T+1;i<6;i++){ time=9+2*i;detail(time); /*函数调用*/if(sum[T]>0) prin tf("\tThe latest free time is %d,%d\n",2*i+8,2*i+10);break;}printf("\t 你想要预定吗?:y/n?");scan f("%s", &c);getchar();if(c=='Y'||c=='y'){if((fp=fope n( "waitlist.txt","r"))==NULL){printf("\n无法打开文件!\n");exit(0);}else{ printf("waitlist : number telephonenumber\n");for(i=0;!feof(fp);i++){fscan f(fp,"%s %s",&wait[i]. nu mber,&wait[i].teleph onenu mber); }fclose(fp);} for(i=0;i<10;i++){ prion e(i);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");if((fp=fope n( "waitlist.txt","a"))==NULL) {printf("\n无法打开文件!\n"); exit(0);} scanf("%s %s",wait[i].number,wait[i].telephonenumber);for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp); /*若等待,就用文件的方式列出当时的等待列表并提示输入你的等待序号和联系方式*/printf(”再次输入电脑的序号!\n");scan f("%d", &y);sum[T]__;computer[T][y]=1;printf("\t好了,请等待我们的电话!\n");Me nu();}else Me nu();}4. 取消预定:void Can cel(){int time ,nu mber;printf("在(8-20)时间范围内输入你已经预定的时间:");sca nf("%d", &time);if(time<8||time>20){printf("\t输入时间错误!\n”);printf("\t在(8-20)时间范围内输入你已经预定的时间:");scan f("%d", &time);}else{printf("\t输入你预定的机号:");sca nf("%d",&nu mber);}detail(time);/* sum[T]++; / *预定后该时间段空机位数加1*//*computer[T] [n umber]=O; / * 预定后该机状态变为0*/ printf("\t 取消成功!\n");getchar();Men u();5. 查询等待信息:void SearchWait in g(){int time,i;FILE *fp;printf("\tln put time you want to search betwee n( 8-20):"); sca nf("%d", &time);if(time<8||time>20){prin tf("\tWro ng time!\n");prin tf("\t In put time you want to search betwee n( 8-20):"); scan f("%d", &time);elseif((fp=fope n( "waitlist.txt","r"))==NULL){prin tf("\nCannot ope n file!\n");exit(0);}else{ printf("waitlist : number telephonenumber\n");for(i=0;!feof(fp);i++){fscan f(fp,"%s %s",&wait[i]. nu mber,&wait[i].teleph onenu mber); } fclose(fp);}for(i=0;i<10;i++){ prion e(i);}Me nu();}输入姓名通过涟表指向等待信息输岀等待信息5程序运行数据及其结果1.主菜单:I CX M i i HM E MnMXXiMJ if J i ltf i t耳*木f| 】相 /方刊页色勺 系纟充“嚥肚M : H UK K JOCK UK K:M X Mi UKKMLKitJCJOCJtJIKNXJCI i tJI柔 单:七占"去*3补114«*»«^选搽菜单号2.机位查询:瘫繼段机位状态4-窕退出言KXXl i tX i K 耳耳KX i M 耳■:址 i KXX「查询基时间段机位状态 2 •预疋空机位 熾執息 轧退出萱畫畫K.青目空空空空空空6: 0 1 网6 7 8 9 11 f.5-S-蛋5-暑 JR 的d&igl:aa-a-a-匚一丄nil rrfl 一rrH rrA rrfl n-fl E EE E E E3.机位预定:择菜些号*«■XXX —XXXXXXXXXX —菜单 XXXXX — XHXX —XXXX —刖由:9<a<M E植耳就算耳N 梵翼拭算址其耳甲拭算箕拉算植光尊拉耳輒其耳拭算就拭耳植廉就算耳植梵覺拭请输入你想要预定的机号,并且留下你的电话号码F : 12345&7再次输入你想要预定的时间?4.查询等待信息:选择菜单号<1-5>:4Input t ine ijou uant to search between t8-20i :9 waitlist : nunber telephonenunbei*6 12345fi 10 12345676课程设计心得课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程 .随着科学技术发展的日新日异,当今计算机应用在生活中可以说得是无处不在。
机房机位预约模拟系统—C语言课程设计
机房机位预约模拟系统—C语言课程设计本报告内容全面翔实质量上乘,程序运行稳定质量高,是获得优秀成绩评定的报告,可以充分满足上机等要求,欢迎交流!本专辑为华中某985重点高校的整个大二班级30份暑期C语言实习报告,涵盖了C语言实习题库的近乎全部内容。
一.题目要求20台机器,从早八点到晚八点,每两个小时一个时间段.需要实现的功能:(1)查询,根据输入的时间,输出机位信息.(2)机位预定,根据输入的日期和时间段查询是否有空机位,若有则预约,若无则提供最近空机时间段.另:若用户要求在非空时间上机,则将用户信息插入该时间段的等待列表.(3)退出预定,根据输入的时间,撤消该时间的预定.二.需求分析根据题目要求,在程序中应实现查询,机位预定,插入等待列表,退出预定,查询等待信息等功能。
还应提供键盘式选择菜单实现功能选择。
而等待信息放在文件里,所以在相关的模块应提供文件的输入、输出操作。
三.总体设计根据上面的需求分析,将这个系统的设计分为下面4个模块:4.详细设计本报告内容全面翔实质量上乘,程序运行稳定质量高,是获得优秀成绩评定的报告,可以充分满足上机等要求,欢迎交流!本专辑为华中某985重点高校的整个大二班级30份暑期C语言实习报告,涵盖了C语言实习题库的近乎全部内容。
1.预处理命令及函数声明#include<tdio.h>#include<tdlib.h>#include<tring.h>#defineN20 {1,1,1,1,1,1,0,0,0,0,0,0,1,1,1,1,1,1,1,1}};/某该数组表示假设某天某人查询时机房各个时间段机位数情况某/voidMenu();voidSituation();voidBook();voidCancel();voidSearchWaiting();voidE某it();voidprintf_one(inti);tructwaitlit{charnumber[3];chartelephonenumber[12];}wait[N];2.主函数主函数一般设计得比较简洁,只提供输入,处理和输出部分的函数调用。
机房机位预约模拟管理系统设计源代码
#include<stdio.h>#include<stdlib.h>#include<string.h>#define SJD 6 /* 宏定义定义SJD Z NULL D(r)*/#define Z 20#define D(s) (s-8)/2 /* 将输入的时间划分时间段;分别为0,1,2,3,4,5 时间段*/#define NULL 0struct xinxi{int jihao;char xuehao[20];struct xinxi *next;}; /* 结构函数包含学生信息:机位,学号,还有下名学生信息*/ struct cell{int RS; /*RS 表示总人数*/struct xinxi *first; /* 第一个预订者记录*/struct xinxi *middle; /* 等待队列列表*/struct xinxi *last; /* 最后预订者记录*/} DUILEI[SJD]; /* 学生时间( SJD )段顺序:人数,第一名学生,排队{的学生,最后一名学生*//*************************** 预定模块******************************/ void yuding()int n;char m[20]; /* 学号*/struct xinxi *R;struct xinxi *p;printf(" 输入想要预定的时间\n"); scanf("%d",&n);if(n>=8&&n<20){n=D(n); /* 将输入的时间划分时间段*/if(DUILEI[n].RS<Z) /* 还有机位可供预订*/{printf(" 请输入你的学号\n");scanf("%s",m);if(DUILEI[n].first==NULL) /* 还没有人预订*/{R=(struct xinxi *)malloc(sizeof(struct xinxi));/* 给R 划分适当的内存*/R->jihao=1;strcpy(R->xuehao,m); /* 将输入的学号复制到R->xuehao */R->next=NULL;DUILEI[n].first=R;DUILEI[n].last=R;DUILEI[n].RS++;printf(" 成功预定\n");}else{R=(struct xinxi *)malloc(sizeof(struct xinxi));strcpy(R->xuehao,m); /* 将输入的学号复制到R->xuehao */ R->next=NULL;p= DUILEI[n].last; /* 将最后预订记录赋值给p*/R->jihao= DUILEI[n].RS+1;printf("%d",R->jihao); /* 表示该时间段第几位预订*/DUILEI[n].last=R; /* 将当前的记录做为最后记录以便形成链表形式指向下一个*/p->next=R;DUILEI[n].RS++; /* 记录人数*/printf(" 预定成功\n");}}else printf(" 没有空余机位!\n");}else printf(" 错误.请输入8~19 ,再次输入.\n");查询空位模********************************** void chaxunkongwei(){int n; printf(" 输入想要查询的时间 (8~19 点,包括 8 点 )\n"); scanf("%d",&n); if(n>=8&&n<20){n=D(n);if(DUILEI[n].RS<Z)printf(" 这里还有 %d 台空电脑 !\n",Z-DUILEI[n].RS);else printf(" 对不起 .没有空余机位 !\n");}else printf(" 错误 ,请输入 8~19 ,再次输入 .\n");************************************ void chaxunyuding(){int n; char m[20];struct xinxi *R;printf(" 输入查询时间 (8~19 点,包括 8 点 )\n"); scanf("%d",&n);if(n>=8&&n<20){n=D(n);printf(" 请输入学号 \n"); */查询预定机位模*/ } }scanf("%s",m);R= DUILEI[n].first; /* 将第一名学生的信息赋予R*/if(DUILEI[n].first==0) printf(" 还没有人预定\n"); /* 判断有没有人预订,如果还没有人预订,则输出还没有人预定*/else{for(;R->next!=NULL;R=R->next) /* 从第一名学生开始查询直到找到符合的学号,以便确认是否预订*/ if(strcmp(R->xuehao,m)==0)break;if(R->jihao!=0) /* 已预订,输出相应的信息*/printf(" 你的机位是%d\n",R->jihao);else printf(" 对不起.你依旧在等待列表中或者没有预定");}}else printf(" 错误,请再次输入.\n");}排队系统模************************************ void paiduixitong(){int n;char m[20];struct xinxi *R; struct xinxi *p;printf(" 请输入想要排队的时间\n");scanf("%d",&n);if(n>=8&&n<20) { n=D(n);if(DUILEI[n].RS>=Z) /* 该时间段没有空位机,需要预订等待*/ {printf(" 请输入你的学号\n"); scanf("%s",m);if((DUILEI[n].RS)==Z){R=(struct xinxi *)malloc(sizeof(struct xinxi)); strcpy(R->xuehao,m);R->next=NULL;R->jihao=0; p= DUILEI[n].last;DUILEI[n].last=R;p->next=R;DUILEI[n].middle=R; /* 等待预订列表*/ DUILEI[n].RS++;printf(" 成功排队\n");}/* 将刚输入学生信息拍到最后一名后,成最后一名*/ else{R=(struct xinxi *)malloc(sizeof(struct xinxi)); strcpy(R->xuehao,m); R->next=NULL;R->jihao=0;p= DUILEI[n].last;DUILEI[n].last=R;p->next=R;DUILEI[n].RS++;printf(" 成功排队\n");}}else printf(" 有空余机位,无须等待\n");else printf(" 错误 .再次输入 .\n");取消预订模*************************************** void cancel(){ int n;int i;char m[20];struct xinxi *R;struct xinxi *q;struct xinxi *p;printf(" 请输入预定的时间 \n");scanf("%d",&n);if(n>=8&&n<20){printf(" 请输入你的学号 !\n");scanf("%s",m);n=D(n);R= DUILEI[n].first;q=R;/* 查找符合信息*/ if(strcmp(R->xuehao,m)==0)break;if(i>Z) /*i>z 表示在等待列表中 */{ if(R->next==NULL){ q->next=NULL;*/for(i=1;;q=R,R=R->next,i++) }DUILEI[n].last=q;free(R);DUILEI[n].RS--;printf(" 取消成功!\n"); /* 如果是排在20 名后,且是最后一名*/ } else{q->next=R->next;free(R);DUILEI[n].RS--;printf(" 取消成功!\n"); /* 如果排在20 名后,但不是最后*/}}else /* 正在上机者取消预订*/{if(DUILEI[n].RS>Z){{DUILEI[n].middle->jihao=R->jihao;DUILEI[n].middle= DUILEI[n].middle->next;} /* 如果排在 20 名内,但总人数(包括等待列表人数)大于 20 */ if(i==1) DUILEI[n].first=R->next;else q->next=R->next;free(R);DUILEI[n].RS--;printf(" 成功取消预定 !\n");}}else printf(" 错误,请再次输入 .\n");待机者列表模*************************** void daijizheliebiao(){int n;struct xinxi *q;printf(" 查询其他等待者的预定时间 \n"); scanf("%d",&n); if(n>=8&&n<20)*/ }n=D(n);if(DUILEI[n].RS>Z) /* 表示有等待上机者*/{printf(" 等待列表:\n");q=DUILEI[n].middle;for(;q->next!=NULL;q=q->next) printf("%s\n",q->xuehao);/* 逐个输出等待列表者信息*/printf("%s\n", DUILEI[n].last->xuehao);}else printf(" 这个时间段没有预定者\n");}else printf(" 错误。
C语言课程设计报告——机房管理系统[1]
目录一.设计内容二.设计要求(1)题目要求(2)输入/输出要求三.整体设计思路四.流程图(1)层次模块图(2)空机号查询N—S图五.主函数及功能菜单说明六.各模块简要说明七.心得体会附录一.源程序代码二.各模块运行结果截图一:设计内容题目:机房管理系统设计机房管理系统,要求由菜单进行管理。
(1)上机前先检查是否有空机位,有则将其显示出,无则提示无空位。
(2)还有空位置时,运行进入,并记录下位置号以及序号,与上机时间。
(3)可对上机者上机信息进行查询,修改与删除。
(4)设计相关模块,显示上机者的上机费用。
(5)显示所有上机者的上机信息。
二:设计要求题目要求:(1)为各项操作功能设计一个菜单。
应用程序运行后,先显示这个菜单,然后用户通过菜单项选择希望进行的操作项目。
(2)要求以上功能分别用函数实现。
输入/输出要求:(1)应用程序运行后,先显示一个菜单,然后用户根据需要选择相应的操作项目。
进入每个操作后,根据程序的提示输入相应的信息。
(2)要求用户输入数据时,要给出清晰、明确的提示信息,包括输入的数据内容、格式及结束方式等。
三:整体设计思路在设计该程序时,要将系统的不同功能分成各个模块。
每个模块由一个函数定义,整个程序由函数调用来实现。
每个模块是一个子函数,由一个主函数调用各个子函数。
在定义子函数时,根据不同的功能选择不同的语句,如需要使用循环时可以用“do……while”来实现;需要使用选择时可以用“switch”或“if”语句来实现等。
设计以菜单方式工作的机房管理系统,主要包括六个模块,分别是上机者信息输入模块,上机者信息查询模块,上机者信息修改模块,上机者信息删除模块,上机者上机费用计算模块,所有上机者信息显示模块。
每个模块由组员相应完成。
另外考虑到机房的特殊要求,新增一个上课模式,此模式功能是将所有机子开启,统一赋上上机者相关信息,避免管理员一个一个的给机子输入信息。
本系统程序关键在于一个空机位的检索,亦是本程序核心之所在。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
c语言课程设计机房机位预定系统绝对正确,附源代码1 设计目的机房机位预定系统2 任务概述20台机器,编号1到20,从早八点到晚八点。
两小时一个时间段,每次可预定一个时间段。
功能要求:(1)系统以菜单方式工作(2)查询,根据输入时间,输出机位信息。
(3)机位预定,根据输入的时间查询是否有空机位,若有则预约,若无则提供最近的时间段,另:若用户在非空时间上机,则将用户信息列入等待列表。
(4)退出预定,根据输入的时间,机器号撤销该事件的预定!(5)查询是否有等待信息,若有则提供最优解决方案(等待时间尽量短),若无则显示提示信息。
.........3 模块划分4 主要函数说明及其N-S图1. 主函数:int main(){Menu(); /*当前状态函数*/}void Menu() /*主界面*/{int n,w;do{puts("\t\t****************机房机位预约系统*******************\n");puts("\t\t*************************菜单***************************\n");puts("\t\t\t 1.查询某时间段机位状态"); /*查询某时间段机位状态*/puts("\t\t\t 2.预定空机位"); /*预定空机位*/puts("\t\t\t 3.取消预订"); /*取消预订*/puts("\t\t\t 4.查询等待信息"); /*查询等待信息*/puts("\t\t\t 5.退出"); /*退出*/puts("\t\t********************************************************\n");printf("选择菜单号(1-5):");scanf("%d",&n);if(n<1||n>5){w=1;getchar();}elsew=0;}while(w==1);switch(n){case 1:Situation();break;case 2:Book();break;case 3:Cancel();break;case 4:SearchWaiting();break;case 5:exit(0);break;}getch();}2.机位查询:void Situation(){int time;printf("输在 (8-20)范围内的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t时间输入错误!\n");printf("输入在 (8-20)范围内的时间:");scanf("%d",&time);}detail(time); /*函数调用*/getchar();Menu();}3.机位预定:void Book(){int time,i=0,x,y;FILE *fp;char c;printf("在(8-20)时间范围内输入你想要预定的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t时间输入错误!\n");printf("\t在(8-20)时间范围内输入你想要预定的时间:");scanf("%d",&time);}detail(time); /*函数调用*/if(sum[T]>0){ if((fp=fopen("waitlist.txt","a"))==NULL){printf("\n无法打开文件!\n");exit(0);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");scanf("%s %s",wait[i].number,wait[i].telephonenumber);for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp);/*向文本文档添加一个结构体单元*/printf("\t再次输入你想要预定的时间!\n");scanf("%d",&x);/*sum[T]--; / *预定后该时间段空机位数减1*//*computer[T][x]=1; / *预定后该机状态变为1*/printf("\t预订成功!\n");getchar();Menu();}else{printf("这是在这个时间段内未预定的电脑!\n");for(i=T+1;i<6;i++){ time=9+2*i;detail(time); /*函数调用*/if(sum[T]>0)printf("\tThe latest free time is %d,%d\n",2*i+8,2*i+10);break;}printf("\t你想要预定吗?:y/n?");scanf("%s",&c);getchar();if(c=='Y'||c=='y'){if((fp=fopen("waitlist.txt","r"))==NULL){printf("\n无法打开文件!\n");exit(0);}else{ printf("waitlist: number telephonenumber\n");for(i=0;!feof(fp);i++){fscanf(fp,"%s %s",&wait[i].number,&wait[i].telephonenumber);}fclose(fp);}for(i=0;i<10;i++){ prione(i);}printf("\n\t请输入你想要预定的机号,并且留下你的电话号码!:\n");if((fp=fopen("waitlist.txt","a"))==NULL){printf("\n无法打开文件!\n");exit(0);}scanf("%s %s",wait[i].number,wait[i].telephonenumber);for(i=0;i<1;i++)fwrite(&wait[i],sizeof(struct waitlist),1,fp);fclose(fp); /*若等待,就用文件的方式列出当时的等待列表并提示输入你的等待序号和联系方式*/printf("再次输入电脑的序号!\n");scanf("%d",&y);sum[T]--;computer[T][y]=1;printf("\t好了,请等待我们的电话!\n");Menu();}else Menu();}}N4.取消预定:void Cancel(){int time,number;printf("在(8-20)时间范围内输入你已经预定的时间:");scanf("%d",&time);if(time<8||time>20){printf("\t输入时间错误!\n");printf("\t在(8-20)时间范围内输入你已经预定的时间:");scanf("%d",&time);}else{printf("\t输入你预定的机号 :");scanf("%d",&number);}detail(time);/* sum[T]++; / *预定后该时间段空机位数加1*//*computer[T][number]=0; / *预定后该机状态变为0*/printf("\t取消成功!\n");getchar();Menu();}5.查询等待信息:void SearchWaiting(){int time,i;FILE *fp;printf("\tInput time you want to search between(8-20):");scanf("%d",&time);if(time<8||time>20){printf("\tWrong time!\n");printf("\tInput time you want to search between(8-20):");scanf("%d",&time);}else;if((fp=fopen("waitlist.txt","r"))==NULL){printf("\nCannot open file!\n");exit(0);}else{ printf("waitlist: number telephonenumber\n");for(i=0;!feof(fp);i++){fscanf(fp,"%s %s",&wait[i].number,&wait[i].telephonenumber);}fclose(fp);}for(i=0;i<10;i++){ prione(i);}Menu();}5 程序运行数据及其结果1.主菜单:2.机位查询:3.机位预定:4.查询等待信息:6 课程设计心得课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.随着科学技术发展的日新日异,当今计算机应用在生活中可以说得是无处不在。