资源简介
校园导航系统.rar

代码片段和文件信息
#define INFINITY 10000
#define MAX_VERTEX_NUM 40
#define MAX 40
#include
#include
#include
#include
typedef struct ArCell
{
int adj; /*路径长度 */
}ArCellAdjMatrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM];
typedef struct /*图中顶点表示主要景点存放景点的编号、名称、简介等信息 */
{
char name[30];
int num;
char introduction[100];/*简介*/
}infotype;
typedef struct
{
infotype vexs[MAX_VERTEX_NUM];
AdjMatrix arcs;
int vexnumarcnum;
}MGraph;
MGraph b;
void cmd(void);
MGraph InitGraph(void);
void show1();
void list();
void Menu(void);
void ShortestPath_DIJ(MGraph * G);
void Search(MGraph *G);
int LocateVex(MGraph *Gchar* v);
/**********主函数************************/
int main()
{
system(“color 0f“); /*修改控制台的颜色信息改为白字蓝底的模式*/
system(“mode con: cols=140 lines=130“); /*设置批处理运行时窗口大小的*/
cmd();
return 0;
}
/********自定义函数***************/
/* cmd函数(根据目录选择要进行的项目)*/
void cmd(void)
{
char k;
b=InitGraph();
show1();
Menu();
while(1)
{
scanf(“\n%c“&k);
switch(k)
{
case ‘1‘:
system(“cls“);
show1();
Menu();
list();
ShortestPath_DIJ(&b);
printf(“---------------------------------欢迎您的使用--------------------------------\n“);
printf(“\n请您继续选择服务:“);
break;
case‘2‘:
system(“cls“);
Menu();
list();
Search(&b);
printf(“---------------------------------欢迎您的使用--------------------------------\n“);
printf(“\n请您继续选择服务:“);
break;
case ‘3‘:
system(“cls“);
printf(“ ┏━━━━━━━━━━━━━━━━━━━━┓\n“);
printf(“ ┃ 感谢使用 ┃\n“);
printf(“ ┃ 南京信息工程大学 ┃\n“);
printf(“ ┃ 导航系统 ┃\n“);
printf(“ ┗━━━━━━━━━━━━━━━━━━━━┛\n“);
exit(0);
default:
printf(“输入信息错误!\n请输入1或2或3.\n“);
break;} }
}
/* 迪杰斯特拉算法来计算出起点到各个顶点之间的最短路径v0为起点 */
void ShortestPath_DIJ(MGraph * G)
{
int vwimint=0xflag=1v0v1have[100]k;
int final[20] D[20] p[23][23];
while(flag)
{
printf(“请输入起始景点编号:\n“);
scanf(“%d“&v0);
if(v0<0||v0>G->vexnum)
printf(“景点编号不存在!“);
printf(“请输入终止景点编号:\n“);
scanf(“%d“&v1);
if(v1<0||v1>G->vexnum)
printf(“景点编号不存在!“);
if(v0>=0&&v0vexnum&&v1>=0&&v1vexnum)
flag=0;
}
for(v=0;vvexnum;++v)
{
final[v]=0;
D[v]=G->arcs[v0][v].adj;
for(w=0;wvexnum;++w)
p[v][w]=INFINITY;
if(D[v] {
p[v][v0]=1;
p[v][v]=1;
}
}
D[v0]=0;
final[v0]=1;
have[0]=v0;
for(i=1;ivexnum;++i)
{
min=INFINITY;
for(w=0;wvexnum;++w)
if(!final[w])
if(D[w] {
v=w;
min=D[w];
}
final[v]=1;
have[k]=v;
k++;
for(w=0;wvexnum;++w)
if(!final[w]&&((min+(G->arcs[v][w].adj)) {
D[w]=min+G->arcs[v][w].adj;
for(x=0;xvexnum;x++)
p[w][x]=p[v][x];
p[w][w]=1;
}
}
for(i=0;ivexnum;i++)
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 175248 2018-06-24 11:16 校园导航.docx
文件 8276 2018-01-07 00:07 1.cpp
----------- --------- ---------- ----- ----
183524 2
- 上一篇:fn_check_creditCode.rar
- 下一篇:霍夫变换找圆.zip
相关资源
- PID_AutoTune_v0.rar
- vspd7.2.308.zip
- 价值2k的H漫画小说系统
- Pythonamp;课堂amp;笔记(高淇amp;400;集第
- ddos压力测试工具99657
- UML建模大全
- 开源1A锂电池充电板TP4056原理图+PCB
- m1卡 ic卡可选择扇区初始化加密软件
- TSCC.exe
- FTP课程设计(服务端+客户端)
- 计算机图形学 边填充算法实现代码
- 电力系统潮流计算程序集合
- oracle数据迁移项目实施方案
- Web Api 通过文件流 文件到本地
- Visio图标-最新最全的网络通信图标库
- Spire API文档
- OpenGL参考手册
- Python中Numpy库最新教程
- SPD博士V5.3.exe
- 直流无刷电机方波驱动 stm32 例程代码
- layui后台管理模板
- 仿知乎界面小程序源代码
- 云平台-阿里云详细介绍
- photoshop经典1000例
- scratch垃圾分类源码(最终版本).sb
- IAR ARM 7.8破解
- TI CCS V5.4 安装步骤及破解文件
- 松下plc FP-XH的驱动
- 局域网硬件信息收集工具
- 加快Windows XP操作系统开机速度
评论
共有 条评论