#include <stdio.h>
#include <time.h>
#include <stdlib.h> #define MAXN 150 //最大节点数
#define INF ((1<<31)-1) //无穷大数 int dist[MAXN][MAXN]; //记录两节点之间的距离
int parent[MAXN][MAXN]; //记录节点a到b路径中b的父节点 double random_d() //生成0~1间的随机数
{
return (double)rand()/RAND_MAX;
} int random_i(int m) //生成0~m间的随机数
{
return (int)(random_d()*(m-) + 0.5);
} void initial(int n) //初始化dist数组和parent数组
{
int a, b;
for(a = ; a < n; a++)
{
for(b = ; b < n; b++)
{
if(a != b)
{
dist[a][b] = INF; //初始阶段距离未知暂时定为无穷大
parent[a][b] = -;
}else{ //此时a等于b
dist[a][b] = ; //节点a到节点a自身的距离是0
parent[a][b] = a;
}
}
}
} void floyd(int n) //floyd算法,计算两点之间的最短距离
{
int a, b, k;
for(k=; k<n; k++)
{
for(a=; a < n; a++)
{
for(b = ; b < n; b++)
{
if(dist[a][k] == INF || dist[k][b] == INF) continue;
if(dist[a][b] > dist[a][k] + dist[k][b])
{
dist[a][b] = dist[a][k] + dist[k][b];
parent[a][b] = parent[k][b];
}
}
}
}
} void generate_graph(int n) //随机生成一张连通图
{
int i, j, v;
initial(n); //进行初始化
for(i = ; i<n; i++) //保证连通性,让0号节点与其他所有点相连
{
dist[][i] = dist[i][] = random_i() + ; //保证算法起作用,加大权值
parent[][i] = ;
parent[i][] = i;
}
for(i=; i<n; i++ )
{
for(j=i+; j<n; j++)
{
v = random_i() ; //随机生成权值
if(v != )
{
dist[i][j] = dist[j][i] = v;
parent[i][j] = i;
parent[j][i] = j;
}
}
}
} void show_graph(int n) //展示节点之间的连接关系及对应的权值
{
int i, j;
for(i=; i<n; i++)
{
for(j=i+; j<n; j++)
if(dist[i][j] != INF) printf("Direct distance between %d and %d: %d\n", i, j, dist[i][j]);
}
} void show_route(int a, int b) //显示a到b的距离最短的路径
{
if(a == b){
printf("%d", b);
}else{
show_route(a, parent[a][b]);
printf("-%d", b);
}
} int main()
{
int a, b;
srand(time(NULL)); //初始化随机数发生器种子 generate_graph(); //随机生成一张连通图
show_graph(); //展示节点之间的连接关系及对应的权值
floyd(); //floyd算法,计算两点之间的最短距离
printf("Please input starting point and end point: "); //提示用户输入两个节点,两个输入之间用逗号隔开,并保证节点编号小于100
scanf("%d %d", &a, &b); //读取用户输入
printf("The distance is %d\n", dist[a][b]); //输出最短距离
printf("The way is ");
show_route(a, b); //输出最短路径
printf("\n");
//printf("%d\n", INF);
return ;
}

sf的更多相关文章

  1. maven 加入json-lib.jar 报错 Missing artifact net.sf.json-lib:json-lib:jar:2.4:compile

    <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</art ...

  2. net.sf.json.JSONException: There is a cycle in the hierarchy!的解决办法

    使用Hibernate manytoone属性关联主表的时候,如果使用JSONArray把pojo对象转换成json对象时,很容易出现循环的异常.解决的办法就是, 在转换json对象时忽略manyto ...

  3. Json_异常_net.sf.json.JSONException: JSONObject["solution"] not found.

    net.sf.json.JSONException: JSONObject["solution"] not found. 没有这个元素造成的. 问题代码: JSONObject j ...

  4. 使用JSONObject遇到的问题,java.lang.NoClassDefFoundError: net/sf/json/JSONObject

    先是报 java.lang.NoClassDefFoundError: net/sf/json/JSONObject 这个错误, 打开项目属性找到java build path中的libaries,找 ...

  5. Net.Sf.Json java Object to JsonObject

    public class People{ private String name; public void setName(String name){ this.name = name; } publ ...

  6. spark mllib配置pom.xml错误 Multiple markers at this line Could not transfer artifact net.sf.opencsv:opencsv:jar:2.3 from/to central (https://repo.maven.apache.org/maven2): repo.maven.apache.org

    刚刚spark mllib,在maven repository网站http://mvnrepository.com/中查询mllib后得到相关库的最新dependence为: <dependen ...

  7. 获取<img src="sdf.jpg" Big="sf.jpg">中的big的值

    原代码: <img src="sdf.jpg" Big="sf.jpg" onclick="getsrc($(this).attr(" ...

  8. java.lang.ClassNotFoundException: net.sf.json.JSONArray,java.lang.NoClassDefFoundError: net/sf/json/JSONArray jetty跑项目遇到的问题

    2016-05-18 15:44:25 ERROR Dispatcher.error[user:|url:]:L38 - Dispatcher initialization failed Unable ...

  9. 【pom.xml 依赖】使用net.sf.json-lib-2.4-jdk15.jar所需要的其他依赖架包 以及其一直在pom.xml报错的问题

    特此声明: json-lib-2.4-jdk15.jar仅它本身不够,必须如下的几个依赖架包都有才能使用!!! 首先 将.json-lib-2.4-jdk15.jar以及其相关的依赖架包的正确配置给出 ...

  10. net.sf.json 时间格式的转化

    后台代码 //后台代码 response.setCharacterEncoding("UTF-8"); JsonConfig jsonConfig = new JsonConfig ...

随机推荐

  1. (原)前端知识杂烩(meta系列)

    更新于 20160831 1. meta 移动端头文件设置 (一般情况下,逐条复制放在头部就可以了) 1.1 强制让文档的宽度与设备的宽度保持1:1,并且文档最大的宽度比例是1.0,且不允许用户点击屏 ...

  2. document.createElement()的用法

    今天做项目需要做个添加地址栏和前面需要一个按钮,就看到了这篇文章! document.createElement()是在对象中创建一个对象,要与appendChild() 或 insertBefore ...

  3. hive 函数学习

    NAME PRICE ---- ----- AAA 1.59 AAA 2.00 AAA 0.75 BBB 3.48 BBB 2.19 BBB 0.99 BBB 2.50 I would like to ...

  4. Qt实现360安全卫士10.0界面(编译时出现的一些问题)

    http://www.qtcn.org/bbs/read-htm-tid-57817.html 源码下载:https://git.oschina.net/zhjun5337/Qt360-10.0  或 ...

  5. js:关于IE6/7下new Date(值)输出为NaN的解决方案

    不得不再次说,万恶的IE,你太守旧了吧,这里出错的原因是IE的时间格式,不是2012-01-23(很多人喜欢用这样的格式) 而是2012/01/23(怎么感觉像是在用VB6和access啊) 搞了好久 ...

  6. ZRender源码分析3:Painter(View层)-上

    回顾 上一篇说到:ZRender源码分析2:Storage(Model层),这次咱看来看看Painter-View层 总体理解 Painter这个类主要负责MVC中的V(View)层,负责将Stora ...

  7. jquery EsayUi 里一个小弹框

    网站后台大多的数据展示就都用和此插件有着密切的关系: 来用一下这个小弹框吧: 一个Html里面的代码 <link rel='stylesheet' type='text/css' href='c ...

  8. web2py官方文档翻译

    00前言 我相信能够轻松地构建高质量增长的web应用程序是至关重要的一个自由和开放的社会.这可以防止玩家最大的垄断信息的流通. 因此我从2007年开始web2py项目,主要是作为一种教学工具与简化we ...

  9. python3.5之string

    刚开始学习python变成, 这勉强算是第一个博客吧, 主要记录了一下 字符串 中的方法, 不太准确,或者是错误的地方, 请大家指点 str1 = "GooGle" str2 = ...

  10. 网络解析 get 和post

    //get同步 - (IBAction)getT:(id)sender { //准备一个Url NSURL *url=[NSURL URLWithString:BASE_URL]; //创建一个请求对 ...