数据结构 校园导游系统的设计与实现(用c++实现)
答案:3 悬赏:60 手机版
解决时间 2021-04-03 14:34
- 提问者网友:战魂
- 2021-04-03 10:29
数据结构 校园导游系统的设计与实现(用c++实现)
最佳答案
- 五星知识达人网友:山河有幸埋战骨
- 2021-04-03 10:51
#include
#include
#include
#include
typedef struct Infor
{
char name[10];
char infor[100];
}Infor;
typedef struct
{ //图的定义
Infor vexs [20] ; //顶点表,用一维向量即可
int arcs[50][50]; //邻接矩阵
int vexnum, arcnum; //顶点总数,弧(边)总数
}Mgraph;
typedef struct
{
char password[6];
char n_password[6];
}PassWord;//密码结构体定义
int LocateVex(Mgraph &G,char a[10])//
{
for(int i=0;i {
if(strcmp(G.vexs[i].name,a)==0)
{
return i;
}
}
cout<<"输入有误!"< return -1;
}
//////////////////////以上是头文件
#include "net.h"
#include//密码功能所需要调用的头文件
void Creategraph(Mgraph &G,PassWord &pw) //构造无向网
{
ifstream inFile("graph.txt");
char v1[10],v2[10];
int i,j,k,w;
inFile>>G.vexnum>>G.arcnum;
for(i=0;i {
inFile>>G.vexs[i].name;
inFile>>G.vexs[i].infor;
}
for(i=0;i<50;i++)
{
for(int j=0;j<50;j++)
{
G.arcs[i][j]=10000;
}
}
for(k=0;k {
inFile>>v1>>v2>>w;
i=LocateVex(G,v1);
j=LocateVex(G,v2);
if(i==j)
{
G.arcs[i][j]=0;
}
else
{
G.arcs[i][j]=w;
G.arcs[j][i]=G.arcs[i][j];
}
}
for(int m=0;m<6;m++)
{
inFile>>pw.password[m];
}
}
/////////////////////////////前台调用的函数/////////////////////////////////////
void infor(Mgraph &G)
{
char a[10];
int b=1;
while(b)
{
for(int i=0;i {
cout< }
cout<<"请输入要查找的景点信息"< cin>>a;
for(i=0;i {
if(strcmp(G.vexs[i].name,a)==0)
{
cout< b=0;
}
}
if(b!=0)
{
cout<<"输入错误请重新输入!!"< }
cout<<"返回前台系统按0,继续查找按1"< cin>>b;
}
}
void ShortestPath (Mgraph G)//最短路径
{
char a[10],d[10];
int b=1,i,j,v,v0,w;
int Dist[100],S[100],Path[100];
int n=G.vexnum;
while(b)
{
for(i=0;i {
cout< }
for(i=0;i<100;i++)
{
Dist[i]=9999;
S[i]=0;
Path[i]=-1;
}
cout<<"请输入要查询路径的两个景点"< cin>>a;
cin>>d;
v0=LocateVex(G,a);
j=LocateVex(G,d);
for(v=0;v {
S[v]=0;
Dist[v]=G.arcs[v0][v];
if(Dist[v]<9999)
Path[v]=v0;//v1是v的前趋
else
Path[v]=-1;//v无前趋
}//
Dist[v0]=0;
S[v0]=1;
for(i=1;i {
int min=9999;
for(w=0;w if(!S[w]&&Dist[w] {
v=w;
min=Dist[w];
}//w顶点离v1顶点更近
S[v]=1;
for(w=0;w if(!S[w]&&(Dist[v]+G.arcs[v][w] {
Dist[w]=Dist[v]+G.arcs[v][w];
Path[w]=v;
}//end if
}//end for
cout<<"距离为:"< cout< cout<<"要经过"< int f=Path[j],e[100];
i=0;
while(f!=-1)
{
e[i]=f;
f=Path[f];
i++;
}
for(v=i-1;v>=0;v--)
{
cout<";
}
cout< cout<<"返回后台系统按0,继续删除按1"< cin>>b;
}
}
void reception(Mgraph &G)//前台
{
int n;
while(1)
{
system("cls");//清屏
cout<<"*********************欢迎使用前台系统************************"< cout<<"(1)景点信息查询"< cout<<"(2)问路查询"< cout<<"(0)返回上一级菜单"< cin>>n;
switch(n)
{
case 1:
infor(G);
break;
case 2:
ShortestPath (G);
break;
case 0:
return;
break;
default:
cout<<"您的输入有误,任意键继续..."< getch();
}
}
}
////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////后台调用的函数///////////////////////////////////
void WriteTXT(Mgraph G,PassWord pw)//将更改后的信息写如graph.txt
{
int i,j;
ofstream outFile("graph.txt");
if(!outFile)
{
cerr<<"cannot open my.txt"< exit(1);
}
outFile< for(i=0;i {
outFile< }
for(i=0;i {
for(j=0;j {
if(G.arcs[i][j]!=10000)
{
outFile< G.arcs[j][i]=10000;
}
}
}
Creategraph(G,pw);
}
void ChangeP(Mgraph &G,PassWord pw)//修改一个已有景点的相关信息
{
char a[10];
int b=1,i;
while(b)
{
for(i=0;i {
cout< }
cout<<"请输入要修改的景点的信息"< cin>>a;
for(i=0;i {
if(strcmp(a,G.vexs[i].name)==0)
{
cout< cout<<"请输入该景点的修改后的信息"< cin>>G.vexs[i].infor;
cout<<"修改成功!!!!"< b=0;
}
}
if(b!=0)
{
cout<<"error!输入有误!"< }
cout<<"保存请按1,不保存请按2"< int c;
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续修改按1"< cin>>b;
}
}
void deleteP(Mgraph &G,PassWord pw)//删除景点信息
{
char a[10];
int b=1,i,j,k;
while(b)
{
for(i=0;i {
cout< }
cout<<"请输入要删除的景点的信息"< cin>>a;
for(i=0;i {
if(strcmp(a,G.vexs[i].name)==0)
{
for(j=i;j {
G.vexs[j]=G.vexs[j+1];
for(k=0;k G.arcs[k][j]=G.arcs[k][j+1];
}
for(j=i;j {
for(k=0;k G.arcs[j][k]=G.arcs[j+1][k];
}
G.vexnum--;
G.arcnum=0;
for(i=0;i {
for(j=0;j {
if(G.arcs[i][j]!=10000)
G.arcnum++;
}
}
G.arcnum=G.arcnum/2;
b=0;
cout<<"删除成功!!!!"< }
}
if(b!=0)
{
cout<<"输入有误!请看清楚!"< }
cout<<"是否要保存?保存按1,不保存按2"< int c;
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续删除按1"< cin>>b;
}
}
void deleteL(Mgraph &G,PassWord pw)//删除路径
{
char a[10],d[10];
int b=1,i,j;
while(b)
{
for(i=0;i {
for(j=0;j {
if(G.arcs[i][j]!=10000)
{
cout< }
}
}
cout<<"请输入要删除的路径连接的两个景点名"< cin>>a;
cin>>d;
i=LocateVex(G,a);
j=LocateVex(G,d);
if(G.arcs[i][j]!=10000)
{
G.arcs[i][j]=10000;
G.arcs[j][i]=10000;
b=0;
cout<<"删除成功!!"< G.arcnum--;
}
if(b!=0)
{
cout<<"输入有误!!"< }
cout<<"保存请按1,不保存请按2"< int c;
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续删除按1"< cin>>b;
}
}
///////////////////////////////////选作//////////////////////////
void Add(Mgraph &G,PassWord &pw)//增加景点
{
cout<<"请输入景点名称:"< cin>>G.vexs[G.vexnum].name;
cout<<"请输入景点信息:"< cin>>G.vexs[G.vexnum].infor;
for(int i=0;i G.arcs[G.vexnum][i]=10000;
for(i=0;i G.arcs[i][G.vexnum]=10000;
G.arcs[G.vexnum][G.vexnum]=0;
G.vexnum++;
cout<<"增加成功!"< cout< WriteTXT(G,pw);
system("pause");system("cls");
}
////////////////////////////////////////////////
bool password(PassWord &pw)//判断密码
{
char p[6];
cout<<"请输入6位密码:"< for(int e=0;e<6;e++)
{
p[e]=getch();
cout<<"*";
cout.flush();
}
cout< for(e=0;e<6;e++)
{
if(p[e]!=pw.password[e])return false;
}
cout< return true;
}
void backstage(Mgraph &G,PassWord pw)//后台函数
{
int n;
while(1)
{
system("cls");
cout<<"*********************欢迎使用后台系统************************"< cout<<"(1)修改一个已有景点的相关信息"< cout<<"(2)删除一个景点及其相关信息"< cout<<"(3)删除一条路径"< cout<<"(4)增加景点"< cout<<"(0)返回上一级菜单"< cin>>n;
switch(n)
{
case 1:
ChangeP(G,pw);
break;
case 2:
deleteP(G,pw);
break;
case 3:
deleteL(G,pw);
break;
case 4:
Add(G,pw);
break;
case 0:
return;
break;
default:
cout<<"您的输入有误,任意键继续..."< getch();
}
}
}
////////////////////////////////////////////////////////////////////////////////////////////////
void main()//主函数
{
Mgraph G;
PassWord pw;
Creategraph(G,pw);
int n,m=1;
while(m)
{
system("cls");
cout<<"*********************欢迎使用北林游览系统************************"< cout<<"(1)前台服务(游客身份登陆)"< cout<<"(2)后台服务(管理员身份登陆)"< cout<<"(0)退出"< cin>>n;
switch(n)
{
case 1:
reception(G);
break;
case 2:
if(password(pw)==true)
{
backstage(G,pw);//后台函数,并调用
}
else
cout<<"密码输入错误!!";
break;
case 0:
m=0;
break;
default:
cout<<"您的输入有误,任意键继续..."< getch();
}
}
}
#include
#include
#include
typedef struct Infor
{
char name[10];
char infor[100];
}Infor;
typedef struct
{ //图的定义
Infor vexs [20] ; //顶点表,用一维向量即可
int arcs[50][50]; //邻接矩阵
int vexnum, arcnum; //顶点总数,弧(边)总数
}Mgraph;
typedef struct
{
char password[6];
char n_password[6];
}PassWord;//密码结构体定义
int LocateVex(Mgraph &G,char a[10])//
{
for(int i=0;i
if(strcmp(G.vexs[i].name,a)==0)
{
return i;
}
}
cout<<"输入有误!"<
}
//////////////////////以上是头文件
#include "net.h"
#include
void Creategraph(Mgraph &G,PassWord &pw) //构造无向网
{
ifstream inFile("graph.txt");
char v1[10],v2[10];
int i,j,k,w;
inFile>>G.vexnum>>G.arcnum;
for(i=0;i
inFile>>G.vexs[i].name;
inFile>>G.vexs[i].infor;
}
for(i=0;i<50;i++)
{
for(int j=0;j<50;j++)
{
G.arcs[i][j]=10000;
}
}
for(k=0;k
inFile>>v1>>v2>>w;
i=LocateVex(G,v1);
j=LocateVex(G,v2);
if(i==j)
{
G.arcs[i][j]=0;
}
else
{
G.arcs[i][j]=w;
G.arcs[j][i]=G.arcs[i][j];
}
}
for(int m=0;m<6;m++)
{
inFile>>pw.password[m];
}
}
/////////////////////////////前台调用的函数/////////////////////////////////////
void infor(Mgraph &G)
{
char a[10];
int b=1;
while(b)
{
for(int i=0;i
cout<
cout<<"请输入要查找的景点信息"<
for(i=0;i
if(strcmp(G.vexs[i].name,a)==0)
{
cout<
}
}
if(b!=0)
{
cout<<"输入错误请重新输入!!"<
cout<<"返回前台系统按0,继续查找按1"<
}
}
void ShortestPath (Mgraph G)//最短路径
{
char a[10],d[10];
int b=1,i,j,v,v0,w;
int Dist[100],S[100],Path[100];
int n=G.vexnum;
while(b)
{
for(i=0;i
cout<
for(i=0;i<100;i++)
{
Dist[i]=9999;
S[i]=0;
Path[i]=-1;
}
cout<<"请输入要查询路径的两个景点"<
cin>>d;
v0=LocateVex(G,a);
j=LocateVex(G,d);
for(v=0;v
S[v]=0;
Dist[v]=G.arcs[v0][v];
if(Dist[v]<9999)
Path[v]=v0;//v1是v的前趋
else
Path[v]=-1;//v无前趋
}//
Dist[v0]=0;
S[v0]=1;
for(i=1;i
int min=9999;
for(w=0;w
v=w;
min=Dist[w];
}//w顶点离v1顶点更近
S[v]=1;
for(w=0;w
Dist[w]=Dist[v]+G.arcs[v][w];
Path[w]=v;
}//end if
}//end for
cout<<"距离为:"<
i=0;
while(f!=-1)
{
e[i]=f;
f=Path[f];
i++;
}
for(v=i-1;v>=0;v--)
{
cout<
}
cout<
}
}
void reception(Mgraph &G)//前台
{
int n;
while(1)
{
system("cls");//清屏
cout<<"*********************欢迎使用前台系统************************"<
switch(n)
{
case 1:
infor(G);
break;
case 2:
ShortestPath (G);
break;
case 0:
return;
break;
default:
cout<<"您的输入有误,任意键继续..."<
}
}
}
////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////后台调用的函数///////////////////////////////////
void WriteTXT(Mgraph G,PassWord pw)//将更改后的信息写如graph.txt
{
int i,j;
ofstream outFile("graph.txt");
if(!outFile)
{
cerr<<"cannot open my.txt"<
}
outFile<
outFile<
for(i=0;i
for(j=0;j
if(G.arcs[i][j]!=10000)
{
outFile<
}
}
}
Creategraph(G,pw);
}
void ChangeP(Mgraph &G,PassWord pw)//修改一个已有景点的相关信息
{
char a[10];
int b=1,i;
while(b)
{
for(i=0;i
cout<
cout<<"请输入要修改的景点的信息"<
for(i=0;i
if(strcmp(a,G.vexs[i].name)==0)
{
cout<
cout<<"修改成功!!!!"<
}
}
if(b!=0)
{
cout<<"error!输入有误!"<
cout<<"保存请按1,不保存请按2"<
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续修改按1"<
}
}
void deleteP(Mgraph &G,PassWord pw)//删除景点信息
{
char a[10];
int b=1,i,j,k;
while(b)
{
for(i=0;i
cout<
cout<<"请输入要删除的景点的信息"<
for(i=0;i
if(strcmp(a,G.vexs[i].name)==0)
{
for(j=i;j
G.vexs[j]=G.vexs[j+1];
for(k=0;k
}
for(j=i;j
for(k=0;k
}
G.vexnum--;
G.arcnum=0;
for(i=0;i
for(j=0;j
if(G.arcs[i][j]!=10000)
G.arcnum++;
}
}
G.arcnum=G.arcnum/2;
b=0;
cout<<"删除成功!!!!"<
}
if(b!=0)
{
cout<<"输入有误!请看清楚!"<
cout<<"是否要保存?保存按1,不保存按2"<
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续删除按1"<
}
}
void deleteL(Mgraph &G,PassWord pw)//删除路径
{
char a[10],d[10];
int b=1,i,j;
while(b)
{
for(i=0;i
for(j=0;j
if(G.arcs[i][j]!=10000)
{
cout<
}
}
cout<<"请输入要删除的路径连接的两个景点名"<
cin>>d;
i=LocateVex(G,a);
j=LocateVex(G,d);
if(G.arcs[i][j]!=10000)
{
G.arcs[i][j]=10000;
G.arcs[j][i]=10000;
b=0;
cout<<"删除成功!!"<
}
if(b!=0)
{
cout<<"输入有误!!"<
cout<<"保存请按1,不保存请按2"<
cin>>c;
if(c==1)
{
WriteTXT(G,pw);
}
cout<<"返回后台系统按0,继续删除按1"<
}
}
///////////////////////////////////选作//////////////////////////
void Add(Mgraph &G,PassWord &pw)//增加景点
{
cout<<"请输入景点名称:"<
cout<<"请输入景点信息:"<
for(int i=0;i
for(i=0;i
G.arcs[G.vexnum][G.vexnum]=0;
G.vexnum++;
cout<<"增加成功!"<
system("pause");system("cls");
}
////////////////////////////////////////////////
bool password(PassWord &pw)//判断密码
{
char p[6];
cout<<"请输入6位密码:"<
{
p[e]=getch();
cout<<"*";
cout.flush();
}
cout<
{
if(p[e]!=pw.password[e])return false;
}
cout<
}
void backstage(Mgraph &G,PassWord pw)//后台函数
{
int n;
while(1)
{
system("cls");
cout<<"*********************欢迎使用后台系统************************"<
switch(n)
{
case 1:
ChangeP(G,pw);
break;
case 2:
deleteP(G,pw);
break;
case 3:
deleteL(G,pw);
break;
case 4:
Add(G,pw);
break;
case 0:
return;
break;
default:
cout<<"您的输入有误,任意键继续..."<
}
}
}
////////////////////////////////////////////////////////////////////////////////////////////////
void main()//主函数
{
Mgraph G;
PassWord pw;
Creategraph(G,pw);
int n,m=1;
while(m)
{
system("cls");
cout<<"*********************欢迎使用北林游览系统************************"<
switch(n)
{
case 1:
reception(G);
break;
case 2:
if(password(pw)==true)
{
backstage(G,pw);//后台函数,并调用
}
else
cout<<"密码输入错误!!";
break;
case 0:
m=0;
break;
default:
cout<<"您的输入有误,任意键继续..."<
}
}
}
全部回答
- 1楼网友:过活
- 2021-04-03 12:54
用《数据结构》的图论,很简单的。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯