C语言实现旅游景点咨询系统

C语言课程设计之旅游景点咨询系统

1.问题描述:创建一个至少有15个点的有向网表示的某个旅游景点的导游图。顶点代表景点,类型为字符串(例如,泰山导游图:“天地广场门”,“十八盘”,“冯玉祥墓”,“桃花峪门”,“中天门”,“南天门”,“玉皇顶”等),弧表示两个景点之间可以直达,弧上的权值表示两个景点之间的路程(公里数),弧上还有到达方法的信息(有步行和索道两种)。建立一个游客咨询系统。

2.基本要求

(1)创建图的存储结构。
(2)输入两个景点名,就可以得到从一个景点到达另一个景点的所有简单路径、相应路径的路程公里数、行走的方法(每一段是步行,还是坐索道);
(3)输入两个景点名,就可以得到其最短路径,即:路程最短的行进方法;如果两者无路径可通,就得出“两景点不可达的信息”。
(4)按照题意要求独立进行设计,设计结束后按要求写出设计报告。

一、代码块:

#include<bits/stdc++.h>
/*#include<iostream>
#include<fstream>
#include<algorithm>
#include<stack>*/
using namespace std;
const int MAXVEX=50;
const int INF=0x3fffffff;
//s表示索道 w表示步行

typedef struct{//边的结构
 int wei;//权值
 char way;//到达方式
}EdgeType;

typedef struct{
 string vexs[MAXVEX];//顶点信息,string类型
 EdgeType arc[MAXVEX][MAXVEX];//边的信息
 int numVertexes,numEdges;//顶点数和边数
}MGraph;

void CreateMGraph(MGraph *G)
{
 FILE *fp;
 fp=fopen("read.txt","r");
 int i,j,k,w;
 cout<<"请输入顶点数和边数"<<endl;
 //cin>>G->numVertexes>>G->numEdges;
 fscanf(fp,"%d %d",&G->numVertexes,&G->numEdges);
 cout<<"请输入"<<G->numVertexes<<"个景点名"<<endl;
 char temp[MAXVEX];
 for(i=0;i<G->numVertexes;++i){
 fscanf(fp,"%s",temp);//cin>>G->vexs[i];
 G->vexs[i]=temp;
 }
 //初始化邻接矩阵
 for(i=0;i<G->numVertexes;++i)
 for(j=0;j<G->numVertexes;++j)
  G->arc[i][j].wei=INF;
 cout<<"请输入"<<G->numEdges<<"条边,包括起点下标、终点下标、路程(KM)和到达方式(s表示索道 w表示步行)"<<endl;
 for(k=0;k<G->numEdges;++k){
 char ch;
 fscanf(fp,"%d %d %d %c",&i,&j,&w,&ch);//cin>>i>>j>>w>>ch;
 G->arc[i][j].wei=w;
 G->arc[i][j].way=ch;
 }
 cout<<endl<<"*******邻接矩阵建立完成,各景点对应的编号如下*******"<<endl<<endl;
 for(i=0;i<G->numVertexes;++i){
 cout<<"编号"<<i<<" "<<G->vexs[i]<<endl;
 }
}

int solution[MAXVEX];//记录路线
bool vis[MAXVEX];//标记数组
int flag;//通路标记

void print(MGraph G,int len)//参数为路径上的第几个点
{
 flag=1;
 int sum=0;
 cout<<G.vexs[solution[1]];
 for(int i=2;i<=len;++i){//第一个点已经打印,打印剩下的点
 if(G.arc[solution[i-1]][solution[i]].way=='s') cout<<" -> "<<"(索道)"<<G.vexs[solution[i]];
 else cout<<" -> "<<"(步行)"<<G.vexs[solution[i]];
 sum+=G.arc[solution[i-1]][solution[i]].wei;
 }
 cout<<endl<<"该路径总路程为"<<sum<<"KM"<<endl;
 cout<<endl;
}

void dfs(MGraph G,int k,int loc,int e)//k为第几步,loc为当前的位置,e为目标
{
 solution[k]=loc;//当前顶点加入路线
 vis[loc]=1;//标记置为1
 if(loc==e) print(G,k);
 else
 for(int i=0;i<G.numVertexes;++i){
 if(vis[i]==0&&G.arc[loc][i].wei<INF) dfs(G,k+1,i,e);
 }
 vis[loc]=0;//取消标记
}

void slove_allpath(MGraph G,int s,int e)//查找所有可行路径
{
 flag=0;//有无路径标记
 memset(vis,0,sizeof(vis));
 dfs(G,1,s,e);//从第一步起点开始
 if(!flag) cout<<"无可行路径!"<<endl;
}

int P[MAXVEX][MAXVEX];//用于存储最短路径下标的数组
int D[MAXVEX][MAXVEX];//用于存储到各点最短路径的权值之和

void ShortestPath_Dijkstra(MGraph G,int v0)//最短路求解
{
 int v,w,k,Min;
 int Final[MAXVEX];//标记,=1表示求得顶点V0至Vw的最短路径
 for(v=0;v<G.numVertexes;v++){//初始化数据
 Final[v]=0;//全部顶点初始化为未知最短路径状态
 D[v0][v]=G.arc[v0][v].wei;//将与V0有连线的顶点加上权值
 P[v0][v]=v0;//初始化路径数组pre顶点均为起始点V0
 }
 D[v0][v0]=0;//v0至v0路径为0
 Final[v0]=1;//v0至v0不需要求路径
 for(v=1;v<G.numVertexes;v++){
 Min=INF;//初始化最小值为INF
 for(w=0;w<G.numVertexes;w++){
  if(!Final[w]&&D[v0][w]<Min){
  k=w;
  Min=D[v0][w];//w顶点离v0顶点更近
  }
 }
 Final[k]=1;//将目前找到的最近的顶点位置置为1
 for(w=0;w<G.numVertexes;++w){//修正当前最短路径及距离
  //如果经过v顶点的路径比现在这条路径的长度短的话
  if(!Final[w]&&(Min+G.arc[k][w].wei<D[v0][w])){
  D[v0][w]=Min+G.arc[k][w].wei;//修改当前路径长度
  P[v0][w]=k;
  }
 }
 }
}

stack<int> xiang;//辅助栈

void slove_ShortestPath(MGraph G,int s,int e)//查找最短路径
{
 int tempe=e;
 if(D[s][e]==INF) cout<<"无可行路径!"<<endl;
 else{//有最短路径
 int temp=D[s][e];
 xiang.push(e);//终点先进栈
 while(P[s][e]!=s)//根据P数组倒着找
 {//只要不到起点
  xiang.push(P[s][e]);
  e=P[s][e];
 }
 //cout<<"由"<<G.vexs[s]<<"到"<<G.vexs[tempe]<<"的最短路径为:"<<endl;
 cout<<G.vexs[s];
 int pre=s;
 while(!xiang.empty())
 {
  int top=xiang.top();
  if(G.arc[pre][top].way=='s') cout<<" -> "<<"(索道)"<<G.vexs[top];
  else cout<<" -> "<<"(步行)"<<G.vexs[top];
  pre=top;
  xiang.pop();
 }
 cout<<endl<<"该路径总路程为"<<temp<<"KM"<<endl;
 }
 cout<<endl;
}

int main()
{
 MGraph G;
 CreateMGraph(&G);
 for(int i=0;i<G.numVertexes;++i) ShortestPath_Dijkstra(G,i);
 /*
 for(int i=0;i<G.numVertexes;++i){
 for(int j=0;j<G.numVertexes;++j)
  cout<<P[i][j]<<' ';
 cout<<endl;
 }
 cout<<endl;
 for(int i=0;i<G.numVertexes;++i){
 for(int j=0;j<G.numVertexes;++j)
  cout<<D[i][j]<<' ';
 cout<<endl;
 }
 */
 cout<<"请输入需要查找的路径(对应的起点和终点下标),输入-1结束查找"<<endl;
 int s,e;
 while(cin>>s>>e&&(s+e)>=0)
 {
 if(s==e){
  cout<<"您已在该景点"<<endl;
  continue;
 }
 cout<<"*******由"<<G.vexs[s]<<"到"<<G.vexs[e]<<"可行的路径有:*******"<<endl;
 slove_allpath(G,s,e);//查找所有可行路径
 cout<<"*******由"<<G.vexs[s]<<"到"<<G.vexs[e]<<"的最短路径为:*******"<<endl;
 slove_ShortestPath(G,s,e);//查找最短路径
 }
 cout<<"********************查 找 结 束********************"<<endl;
 return 0;
}

二、运行:

1.读入景点信息文件:

2.查找:

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言利用结构体数组实现学生成绩管理系统

    要求: 某班有最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体门数由键盘输入).定义结构体类型描述学生信息,每个学生信息包括:学号.姓名.多门课的成绩.总成绩和平均成绩.用结构体数组作为函数参数,编程实现如下菜单驱动的学生成绩管理系统. (1) 录入每个学生的学号.姓名和各科考试成绩. (2) 计算每门课程的总分和平均分. (3) 计算每个学生的总分和平均分. (4) 按每个学生的总分由高到低排出名次表. (5) 按学号由小到大排出成绩表. (6) 按姓名的字典顺序排出成

  • C语言职工信息管理系统源码

    本文实例为大家分享了C语言职工信息管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <conio.h> struct worker { char ID[20];//工号 char name[20];//姓名 char sex[5];//性别 char born[20];//生日 char edu[20];//学历 char po

  • C语言通讯录管理系统完整版

    C语言实现了通讯录的录入信息.保存信息.插入.删除.排序.查找.单个显示等功能.. 完整的代码如下: #include <stdio.h> #include <malloc.h> //得到指向大小为Size的内存区域的首字节的指针// #include <string.h> #include <stdlib.h> //标准库函数// #define NULL 0 #define LEN sizeof(struct address_list) //计算字节//

  • 学生成绩管理系统C语言代码实现

    C语言实现了学生成绩管理系统,可以进行学生成绩的增加,删除,更新,查询,计算和展示. 完整代码如下: #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct person //定义结构体 { char num[10]; //学号 char name[20]; //姓名 float cyuyan; //C语言成绩 float en; //物理学成绩 float ji; //原子物理成绩

  • C语言学生管理系统源码分享

    本文实例为大家分享了C语言学生管理系统源码,供大家参考,具体内容如下 #include<stdio.h> #include<stdlib.h> //结构体可以存放的学生信息最大个数,不可变变量 int const MAX_LENGTH=100; //学生信息结构体数组,最多可以存放100个学生信息 struct student{ int id; //学号 char *name; //姓名 int age; //年龄 float c_score; //C语言成绩 float engl

  • C语言学生成绩管理系统源代码

    大学C语言实训课,C语言学生成绩管理系统,供大家参考,具体内容如下 #include<stdio.h> #include<string.h> #include<math.h> struct student { int num; char name[20]; float pingshi; float shiyan; float kaoshi; double zongping; }stu[4]; void main() { void a(); void b(); void

  • C语言编写学生成绩管理系统

    用C语言编写学生成绩管理系统代码,供大家参考,具体内容如下 C语言实现学生成绩管理系统实战教学 https://www.jb51.net/article/154767.htm (1)给出所选课程设计题目以及本题目具体所要完成的功能要求说明. 1.课程设计题目:学生成绩管理系统 2.完成的功能要求: (1).主要实现的功能: 1---学生输入 2---学生插入 3---学生查询(按学号) 4---学生删除 5---学生输出 6---计算每名学生的平均分并输出 7---计算每科的平均分并输出 8--

  • C语言图书管理系统简洁版

    DOS界面的图书管理系统,具体内容如下 程序分为两块:管理员操作(收录图书.删除图书等)和会员操作(注册.借书.还书等): 1.管理员操作界面 2.会员操作界面 global.h头文件:(程序中只使用了一个编写的头文件,在这里存放了所有的接口函数以及需要使用到的头文件,还有结构体的定义) #include "iostream" #include "string" #include "fstream" #include "conio.h&

  • 学生信息管理系统C语言版

    C语言学生信息管理系统包括以下功能: 1.学生信息的整体注册 2.学生信息的修改 3.学生成绩信息的录入 4.学生信息的添加 5.恢复误删的学生信息 6.学生信息的删除 7.密码修改保存函数 8.学生信息的查询 9.密码修改函数 10.学生信息管理系统的菜单函数 #include "stdio.h" #include "malloc.h" #include "string.h" #include "stdlib.h" #inc

  • C语言实现旅游景点咨询系统

    C语言课程设计之旅游景点咨询系统 1.问题描述:创建一个至少有15个点的有向网表示的某个旅游景点的导游图.顶点代表景点,类型为字符串(例如,泰山导游图:"天地广场门","十八盘","冯玉祥墓","桃花峪门","中天门","南天门","玉皇顶"等),弧表示两个景点之间可以直达,弧上的权值表示两个景点之间的路程(公里数),弧上还有到达方法的信息(有步行和索道两种).建立一

  • Python爬虫入门案例之爬取去哪儿旅游景点攻略以及可视化分析

    目录 知识点 第三方库 开发环境: 爬虫程序 导入模块 发送请求 获取数据(网页源代码) 解析网页(re正则表达式,css选择器,xpath,bs4/六年没更新了,json) 向详情页网站发送请求(get,post) 解析网页 保存数据 数据可视化 导入模块 导入数据 旅游胜地Top10及对应费用 出游方式分析 出游时间分析 出游玩法分析 知识点 requests 发送网络请求 parsel 解析数据 csv 保存数据 第三方库 requests >>> pip install requ

  • C语言实现旅游资讯管理系统

    本文实例为大家分享了C语言实现旅游资讯管理系统的具体代码,供大家参考,具体内容如下 题目: 一.主体功能点要求 1.设计主菜单实现用户交互 a.添加旅游资讯记录每条记录至少包含如下项:编号.日程安排.费用.点赞数.添加旅游资讯记录时,要求键盘输入对应的编号.日程安排等信息.添加成功后屏幕打印出相应的提示信息.b.查询旅游资讯记录查询旅游资讯记录时,打印相应提示语句,用户输入“1~3”之间的整数,如果输入1,按编号大小升序排序显示所有的记录:如果输入2,按点赞数降序排序显示所有的记录:如果输入3,

  • Java 实战项目之诚途旅游系统的实现流程

    采用ssm架构实现的旅游网站系统 包括网站展示和后台管理功能,网站主要是页面浏览以及评论.制定旅游方案.智能推荐功能 后台就是维护网站展示的内容,添加旅游景点.管理用户.查看用户的搜索记录功能 酒店信息控制层: /** * 控制器层 * */ @Controller @CrossOrigin @RequestMapping("/hotel") public class HotelController { @Autowired private HotelService hotelServ

  • C++实现景区旅游信息管理系统

    本文实例为大家分享了C++实现景区旅游信息管理系统的具体代码,供大家参考,具体内容如下 1 问题描述 如今生活水平提高,大家都喜欢在假期中到一个旅游景点参观,在旅游景区中经常听到游客打听从一个景点到另一个景点的最短路径和最短距离,这类不喜欢按照导游图来游览的游客常常需要一个景区管理系统来挑选自己喜欢的旅游景点,再规划一个最短路径和最短距离来游览,一边节省时间跟提高旅游效率. 2 数据结构的设计 建立一个景区旅游信息管理系统,实现如下功能: 1.创建景区景点分布图 通过一个邻接矩阵(实质是一个二维

  • jQuery鼠标经过方形图片切换成圆边效果代码分享

    这是一款基于jQuery鼠标经过方形图片切换成圆边特效代码,点击图片会弹出浮层,用户还可以自定义对应图片的标题与文字说明,适合图片页面的展示,是一款非常实用的图片特效源码. 运行效果图: --------------------------------效果演示 源码下载---------------------------------- 鼠标经过方形图片切换成圆边效果 点击图片会弹出浮层 为大家分享的jQuery鼠标经过方形图片切换成圆边效果代码如下 <head> <title>j

  • C++用Dijkstra(迪杰斯特拉)算法求最短路径

    算法介绍 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Dijkstra算法能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低. 算法思想 按路径长度递增次序产生算法: 把顶点集合V分成两组: (1)S:已求出的顶点的集合(初始时只含有源点V0) (2)V-S=T:尚未确定的顶点集合 将T中顶点按递增

  • C++实现景区信息管理系统

    本文实例为大家分享了C++实现景区信息管理系统的具体代码,供大家参考,具体内容如下  1.1 建立主程序应用菜单选项 主程序应用菜单选项包含所实现的所有功能,并且对选项采用数字标识进行选择,对其他错误输入可以进行判别,提示输入错误. 1.2 导游线路图的创建级景区分布图的输出 用邻接链表存储景点分布图的信息,(带权无向)图的邻接链表.输出景区景点分布图(邻接矩阵).图中边的权值∞用32767表示. 1.3  输出导游线路图 景区旅游信息管理系统中制订旅游景点导游线路策略,首先通过遍历景点,给出一

  • redis限流的实际应用

    为什么要做限流 首先让我们先看一看系统架构设计中,为什么要做"限流". 旅游景点通常都会有最大的接待量,不可能无限制的放游客进入,比如故宫每天只卖八万张票,超过八万的游客,无法买票进入,因为如果超过八万人,景点的工作人员可能就忙不过来,过于拥挤的景点也会影响游客的体验和心情,并且还会有安全隐患:「只卖N张票,这就是一种限流的手段」. 软件架构中的服务限流也是类似,也是当系统资源不够的时候,已经不足以应对大量的请求,为了保证服务还能够正常运行,那么按照规则,「系统会把多余的请求直接拒绝掉

  • 写一个Python脚本自动爬取Bilibili小视频

    我身边的很多小伙伴们在朋友圈里面晒着出去游玩的照片,简直了,人多的不要不要的,长城被堵到水泄不通,老实人想想啊,既然人这么多,哪都不去也是件好事,没事还可以刷刷 B 站 23333 .这时候老实人也有了一个大胆地想法,能不能让这些在旅游景点排队的小伙伴们更快地打发时间呢?考虑到视频的娱乐性和大众观看量,我决定对 B 站新推出的小视频功能下手,于是我跑到B站去找API接口,果不起然,B站在小视频功能处提供了 API 接口,小伙伴们有福了哟! B 站小视频网址在这里哦: http://vc.bili

随机推荐