程序设计旅游管理系统.docx
- 文档编号:9476323
- 上传时间:2023-02-04
- 格式:DOCX
- 页数:71
- 大小:48.84KB
程序设计旅游管理系统.docx
《程序设计旅游管理系统.docx》由会员分享,可在线阅读,更多相关《程序设计旅游管理系统.docx(71页珍藏版)》请在冰豆网上搜索。
程序设计旅游管理系统
程序设计报告
(2015/2016学年第二学期)
题目:
旅游管理系统
旅游管理系统
一、课题内容和要求
旅游管理系统是某旅行社的旅游管理系统,具有排序,查找,计算,显示等功能。
通过此课题,熟练账务文件,数组,指针的各种操作,以及一些算法思想的应用。
功能要求:
旅游管理系统信息应包括:
(其中房源和客户的信息应该根据日常情况进行合理设置)
基础信息:
旅行社信息,线路信息,员工信息等
业务管理:
业务登记,确认出游,业务结算等
信息查询:
线路信息查询、人员信息查询、业务登记查询、确认出游查询、业务结算查询等
统计分析:
登记业务汇总表、确认出游汇总表、业务结算汇总表、期间结算统计等。
需要实现的功能:
1)用户需要输入口令进入旅游管理系统
2)实现所有相关信息的建立
3)计算系统的业务数量,查询各类线路的需求状况
4)按照线路或者出行人数进行排序,显示相关信息
5)统计某时间段内的销售业绩,统计收入。
6)将本系统的所有相关信息内容存为文件。
界面友好,费用的收取应该符合常规。
.
二、需求分析
示。
所1旅游管理系统的功能框架图如图
旅游管理系统
基础信息
业务管理
信息查询s[i]
开始,调用?
ac==‘N'?
s[i]输入姓名i=0的字符入相等YY/N由.acc和
统计分析线路信息查询人员信息查询业务登记查询确认出游查询业务结算查询NN和输出
旅行社信息线路信息员工信息Yac==‘Y'Y
业务登记i=0
登记业务总汇表
确认出游S[i].acc=1开始,调用
N信息
确认出游总汇表
业务结算
业务结算总汇表
增加记录输
串
期间结算统计
删除记录s[i].name
i++
修改记录S[i].ack=1输出改游客的信息。
.ack注:
图1功能框架图
)提供可操作的主菜单:
输出个菜单,用于显示以从文件中加载的总客户信息和1(.
若干个可选的功能选项。
根据客户输入的选项来运行不同的功能,运行不同的函数。
(2)基础信息查询:
通过调用文件,查询旅行社的基本信息。
(3)业务管理:
调用结构体,有三个功能,业务登记是将需要输入的信息写入结构体,确认出游是为确认出游赋值(1或0),业务结算时将输入的信息进行初步处理。
(4)信息查询:
通过调用函数对结构体信息进行处理,输出相应数据。
(5)统计分析:
输出相应的表格。
(6)密码函数:
将输入的字符转化为“*”。
(7)输入函数:
将数据输入结构体。
(8)分析函数:
分析那些游客选择了什么服务。
(9)输出函数:
将处理好的数据以表格形式输出。
(10)保存函数,将数据保存为文件。
(11)处理函数:
对结构体的数据进行插入,修改,删除等处理。
三、概要设计
1主要结构体
structtourist//定义结构体
{
charname[10];//游客姓名
introut;//路线选择
charPNum[11];//联系方式
intacc;//是否住宿
intack;//确认出游
};
2主要函数流程图写入函数:
)(1
开始
j
输入游客数量N
20?
j≤Y
输入第i个游客数据
Y
图2写入函数
定义i,j,j为输入的游客总量,利用do-while语句保证输入的值在0-20之间,然后通过for循环一个个输入每一个游客的信息。
(2)输出登记函数:
定义整型i,字符型ac,ak,通过for循环一个个判断每个游客输出的信息该为Y(Yes)还是N(No)。
如果s[i].acc==1即,这个游客的.acc项为“真”,给这一个字符型ac赋值为Y,如果s[i].acc==0,这个游客的.acc项为“假”,给这个字符型ac赋值为N,字符型ak同理,然后在一个循环内利用printf函数输出这一个游客的信息,然后跳入下一个循环。
总共有len个游客。
ak==‘Yak==‘N'
图3输出函数
(3)查找游客信息
定义字符串str_a[20],定义整型i=0,用scanf函数输入姓名信息,通过strcmp函数比较str_a[20]和原结构体中储存的s[i].name的内容,如果相同则输出游客的信息,此时游客的确认出游和是否住宿可以参照上一个函数示例输出为Y(Yes)和N(No),如果不同则通过for循环使i++,对比下一个s[i].name,直到查找到游客的信息。
i++
完成.
图4查找功能
(4)输出路线选择:
该函数分为两个部分,一个是统计每条路线有多少人,一个是谁选了这条路线。
定义整型i,j,sum1,sum2,sum3,由i<=j确保for循环不超过结构体中的游客数量,然后是第一个判断,通过前面设计的路线代码,如果s[i].rout==其中一个路线代码时,sum中的一个制就加一,然后通过for循环,逐个判断每个游客选择的路线,最终输出每个路线有多少人选择。
然后定义i=0,通过s[i].rout的值判断并输出s[i].name,最终达到输出选择该路线的人有谁这个目的。
Sum1+1
Sum2+1
开i=0Ys[i].rout=50?
NY
i++s[i].rout=75?
NN
Y
s[i].rout=60?
Sum3+1Y
j?
N输出每条路线有多少游结
图5输出路线
开始
i=0,k=1
i++
Y
图6输出姓名
(5)输出统计表格(排序对比):
通过累加s[i].acc的值(for循环),来确定最终由多少人住宿然后输出改质乘以住宿费用得出住宿的收入,然后累加s[i].rout的值确定路线收入的值,通过+=算法算出每一条路线的总收入,再用逻辑与和比较法得出那一条路线收入最高。
开
计算得出住宿和路的收入,列表显
比较每条路线的总收入并出哪一条最高
输出结
结束
比较收入7图
四、源程序代码(打印目录图案时的printf函数内容可能会乱,实际显示没问题)
#include
#include
#include
#include
#include
#include
#include
#include
#defineMAX_PASSWD_LEN16
#defineNUM20
#definesizessizeof(tourist)
structtourist//定义结构体
{
charname[10];
introut;
charPNum[11];
intacc;
intack;
};
typedefstructtouristtourist;//结构体名称为tourist
voidinsert(tourists[],inti)//插入游客
{
system(cls);
牰湩晴?
输入增加的游客:
\n);
scanf(%s%d%s%d%d,&s[i].name,&s[i].rout,&s[i].PNum,&s[i].acc,&s[i].ack);
}
voidchange(tourists[],intj)//修改游客
{
system(cls);
inti,num=j;
charstr_a[20];
牰湩晴?
输入需要修改游客的名字:
\n);
scanf(%s,str_a);
for(i=0;i { if(strcmp(s[i].name,str_a)==0) { printf(%s,%d,%s,%d,%d\r\n,&s[i].name,s[i].rout,&s[i].PNum,s[i].acc,s[i].ack); 牰湩晴? 输入修改的信息: \n); scanf(%s%d%s%d%d,&s[i].name,&s[i].rout,&s[i].PNum,&s[i].acc,&s[i].ack); } } } voiddeletes(tourists[],intj)//删除游客 { system(cls); inti,num=j; charstr_a[20]; 牰湩晴? 输入需要删除游客的名字: \n); scanf(%s,str_a); for(i=0;i { if(strcmp(s[i].name,str_a)==0) for(i;i { s[i]=s[i+1]; } } } intInput(tourists[])//输入数据 { inti,j; do { 牰湩晴? 输入游客数量(不超过20人): \n); scanf(%d,&j); } while(j<=0||j>20); { system(cls); 牰湩晴? 输入登记信息(格式: 姓名,路线,联系方式,是否住宿,确认出游.): \n); 牰湩晴? 路线输入代码1: 50,2: 75,3: 60.住宿选1,不住宿选0\n); } for(i=0;i { 牰湩晴? 输入第%d个游客: \n,i+1); scanf(%s%d%s%d%d,&s[i].name,&s[i].rout,&s[i].PNum,&s[i].acc,&s[i].ack); printf(%s,%d,%s,%d,%d\r\n,&s[i].name,s[i].rout,&s[i].PNum,s[i].acc,s[i].ack); } printf(Inputisfinished.\r\n); returnj; } voidOutput(consttourists[],intlen)//输出登记信息 { system(cls); inti,ro; charac,ak; for(i=0;i { if(s[i].acc==1) { ac='Y'; } if(s[i].acc==0) { ac='N'; } if(s[i].ack==1) { ak='Y'; } if(s[i].ack==0) { ak='N'; } if(s[i].rout==50) { ro=1; } if(s[i].rout==75) { ro=2; } if(s[i].rout==60) { ro=3; } 牰湩晴? 姓名: %s,路线: %d,联系方式: %s,是否住宿: %c,确认出游: %c\n,&s[i].name,ro,&s[i].PNum,ac,ak); } } intSum0(tourists[],intj)//确认住宿收入 { inti,ret=0,num=j; for(i=0;i { ret+=s[i].acc; } ret=ret*50; \n,ret); 元%d住宿收入牰湩晴? returnret; } intSum1(tourists[],intj)//确认住宿和住宿情况 { inti,ret=0,num=j; for(i=0;i { ret+=s[i].acc; } 牰湩晴? 总共有%d个游客住宿,,ret); if(ret<=10) { 牰湩晴? 房源充足\n); } else { 牰湩晴? 房源紧缺\n); } returnret; } intSum2(tourists[],intj)//确认景点收入 { inti,ret=0,num=j; for(i=0;i { ret+=s[i].rout; } 牰湩晴? 景点收入%d元\n,ret); returnret; } intSum3(tourists[],intj)//确认出游 { inti,ret=0,num=j; for(i=0;i { ret+=s[i].ack; } 牰湩晴? 共%d个游客确认出游,ret); returnret; } intc1(tourists[],intj)//输出登记表格 { inti,ret=0,num=j; intro; charac; printf(|------------------------------------------------------|\n); printf(|||||\n); printf(|名字|路线|电话|是否住宿|\n); printf(|||||\n); for(i=0;i { if(s[i].acc==1) { ac='Y'; } else { ac='N'; } if(s[i].rout==50) { ro=1; } if(s[i].rout==75) { ro=2; } if(s[i].rout==60) { ro=3; } printf(|------------------------------------------------------|\n); printf(|||||\n); |\n,&s[i].name,ro,&s[i].PNum,ac);%c|s||printf(|_x0010_s%d |\n);||printf(|| } printf(|------------------------------------------------------|\n); returnret; } //输出确认出游的表格intc2(tourists[],intj) { inti,num=j; printf(|-----------------------------|\n); |\n);printf(|| |\n);姓名|确认出游printf(| |\n);printf(|| printf(|-----------------------------|\n); for(i=0;i { if(s[i].ack==1) { printf(|||\n); printf(|_x0010_s|确认|\n,&s[i].name); printf(|||\n); } if(s[i].ack==0) { printf(|||\n); printf(|_x0010_s|否认|\n,&s[i].name); printf(|||\n); } printf(|-----------------------------|\n); } return0; } intc3(tourists[],intj)//输出收入表格 { inti,ret=0,num=j,z=0,x=0,c=0,v=0; for(i=0;i { if(s[i].acc==1) { ret+=1; } else { ret+=0; } if(s[i].rout==50) { z+=1; } if(s[i].rout==75) { x+=1; } if(s[i].rout==60) { c+=1; } } v=z*50+x*75+c*60; printf(|-------------|---------------------|\n); |\n); |printf(| printf(|项目|价钱|\n); printf(|||\n); printf(|-------------|---------------------|\n); printf(|||\n); printf(|住宿|]|\n,ret*50); printf(|||\n); printf(|-------------|---------------------|\n); printf(|||\n); printf(|线路|]|\n,v); printf(|||\n); printf(|-------------|---------------------|\n); return0; } voidc4(tourists[],intj)//统计输出 { inti,num=j,z=0,x=0,c=0; for(i=0;i { if(s[i].rout==50) { z+=50; } if(s[i].rout==75) { x+=75; } if(s[i].rout==60) { c+=60; } } 牰湩晴? 路线一收入%d元,路线二收入%d元,路线三收入%d元.,z,x,c); if(z==c&&x==c) { 牰湩晴? 路线一二三收入一样高\n); } if(z==c&&z>x) { 牰湩晴? 路线一和三收入同样是最高的\n); } if(z==x&&z>c) { 牰湩晴? 路线一和二收入同样是最高的\n); } if(x==c&&x>z) { 牰湩晴? 路线二和三收入同样是最高的\n); } if(z>x&&z>c) { 牰湩晴? 路线一收入最高\n); } if(x>c&&x>z) { 牰湩晴? 路线二收入最高\n); } if(c>z&&c>x) { 牰湩晴? 路线三收入最高\n); } } voidackput(tourists[],intj)//输出确认出游的游客 { inti,num=j; for(i=0;i { if(s[i].ack==1) { printf(%-10s\n,&s[i].name); } else { printf(\); } } } voidroutput(tourists[],intj)//输出路线选择 { inti,num=j; intsum1=0,sum2=0,sum3=0; for(i=0;i { if(s[i].rout==50) { sum1+=1; } if(s[i].rout==75) { sum2+=1; } if(s[i].rout==60) { sum3+=1; } intcompare,sign; for(compare=1;compare<76;compare++) { if(s[i].rout==compare) { sign=1; break; } else { sign=0;} } if(sign==0) { printf(error\n); } } 牰湩晴? 选择路线一的有%d人,选择路线二的有%d人,选择路线三的有%d人\n,sum1,sum2,sum3); i=0; 牰湩晴? 选择路线一的有: \n); for(i=0;i { if(s[i].rout==50) { printf(%-10s\n,&s[i].name); } else { printf(\); } } 牰湩晴? 选择路线二的有: \n); i=0; for(i=0;i { if(s[i].rout==75) { printf(%-10s\n,&s[i].name); } else { printf(\); } } 牰湩晴? 选择路线三的有: \n); i=0; for(i=0;i { if(s[i].rout==60) { printf(%-10s\n,&s[i].name); } else { printf(\); } } } inttouristSear(tourists[],intj)//人员查询 { system(cls); inti,num=j,z=0; intro; charac,ak;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 旅游 管理 系统