资源简介
如标题所示,一个dijkstra的c代码,标准输入输出
代码片段和文件信息
#include
#include
#define MAXINT 32767
int arr[15][15];
int rec[15];
void init()
{
int i j;
int tx ty t;
FILE *in;
in = fopen(“test.in“ “r“);
for (i=0; i<15; i++)
{
for (j=0; j<15; j++)
{
arr[i][j] = MAXINT;
}
arr[i][i] = 0;
}
for (i=0; i<30; i++)
{
fscanf(in “%d %d %d“ &tx &ty &t);
arr[tx][ty] = t;
arr[ty][tx] = t;
}
}
void dijkstra()
{
int i j k;
int visit[50] = {0};
int min minj;
for (i=1; i<=10; i++)
{
rec[i] = arr[1][i];
}
visit[1] = 1;
for (i=1; i<=10; i++)
{
min = MAXINT;
for (j=1; j<=10; j++)
{
if (rec[j] < min && visit[j] != 1)
{
min = rec[j]; //这里是一个相当容易错的地方!!!对算法的理解要透彻!
minj = j;
}
}
visit[minj] = 1;
if (min == MAXINT)
{
return;
}
for (j=1; j<=10; j++)
{
if (rec[minj] + arr[minj][j] < rec[j] && visit[j] == 0 && minj != j)
{
rec[j] = rec[minj] + arr[minj][j];
}
}
}
}
void Disp()
{
int i;
for (i=1; i<=10; i++)
{
printf(“%d “ rec[i]);
}
printf(“\n“);
}
int main()
{
init();
dijkstra();
Disp();
getch();
return 0;
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 17614 2009-08-13 08:02 test.exe
文件 275 2009-08-10 20:06 test.in
文件 1187 2009-08-14 08:30 test.c
----------- --------- ---------- ----- ----
19076 3
相关资源
- 基于MFC的TCP调试助手源码95706
- 国际象棋的qt源代码
- 操作系统c语言模拟文件管理系统844
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- 基于mfc的多线程文件传输
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 利用C++哈希表的方法实现电话号码查
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 移木块游戏,可以自编自玩,vc6.0编写
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- C++纯文字DOS超小RPG游戏
- 个人日常财务管理系统(C语言)
- MFC数字钟(基于VC6.0)
- c语言电子商务系统
川公网安备 51152502000135号
评论
共有 条评论