HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj2253--最短路Dijkstra
題意描述:
公青蛙a要找到母青蛙b,他要跳過若干塊石頭到達b處,他并不關心走過總路程的長短,但是希望單次跳動的長度最短。
最短路Dijkstra算法。
#include
<
stdio.h
>
#include
<
stdlib.h
>
#include
<
math.h
>
#define
LEN 210
#define
MAX 100000
typedef
struct
{
double
x;
double
y;
}
Point;
int
main()
{
int
i, j;
int
n;
int
x, y;
double
mp[LEN][LEN];
Point ps[LEN];
scanf(
"
%d
"
,
&
n);
int
count
=
1
;
while
(n
!=
0
)
{
//
//
printf("n = %d\n", n);
//
for
(i
=
0
; i
<
n; i
++
)
scanf(
"
%lf%lf
"
,
&
ps[i].x,
&
ps[i].y);
for
(i
=
0
; i
<
n; i
++
)
for
(j
=
i
+
1
; j
<
n; j
++
)
{
double
dx
=
ps[i].x
-
ps[j].x;
double
dy
=
ps[i].y
-
ps[j].y;
mp[i][j]
=
mp[j][i]
=
sqrt(dx
*
dx
+
dy
*
dy);
}
for
(i
=
0
; i
<
n; i
++
)
mp[i][i]
=
MAX;
double
minlenall
=
-
MAX;
int
s[LEN]
=
{
0
}
;
double
cost[LEN];
int
pre[LEN];
for
(i
=
0
; i
<
n; i
++
)
{
cost[i]
=
mp[
0
][i];
if
(mp[
0
][i]
!=
MAX)
pre[i]
=
0
;
else
pre[i]
=
-
1
;
}
s[
0
]
=
1
;
pre[
0
]
=
-
1
;
for
(j
=
0
; j
<=
n
-
2
; j
++
)
//
dijkstra
{
int
t
=
0
;
double
min
=
MAX;
for
(i
=
0
; i
<
n; i
++
)
//
find min
if
(s[i]
==
0
&&
cost[i]
<
min)
{
min
=
cost[i];
t
=
i;
}
s[t]
=
1
;
//
into S[]
for
(i
=
0
; i
<
n; i
++
)
//
update
{
if
(s[i]
==
0
&&
mp[t][i]
<
cost[i])
{
cost[i]
=
mp[t][i];
pre[i]
=
t;
}
}
}
int
tt
=
1
;
int
tt1
=
pre[tt];
while
(pre[tt]
!=
-
1
)
{
if
(mp[tt][tt1]
>
minlenall)
minlenall
=
mp[tt][tt1];
tt
=
tt1;
tt1
=
pre[tt1];
}
printf(
"
Scenario #%d\n
"
, count
++
);
printf(
"
Frog Distance = %.3lf\n\n
"
, minlenall);
scanf(
"
%d
"
,
&
n);
}
//
system("pause");
}
posted on 2012-08-07 23:51
小鼠標
閱讀(129)
評論(0)
編輯
收藏
引用
所屬分類:
圖論
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
hdu3549--網絡流
poj1273--網絡流
hdu3118Arbiter
poj2488--回溯
poj2386--圖的遍歷
hdu3342--拓撲排序
hdu1285--拓撲排序
zoj1060,poj1094--拓撲排序
poj1135--Dijkstra
poj3268--Dijkstra
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 Powered by:
博客園
模板提供:
滬江博客
<
2012年8月
>
日
一
二
三
四
五
六
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(111)
C語言(3)
DP(9)
Java筆記(1)
Java基礎練習(25)
安卓(1)
本科畢設(1)
博弈(1)
大數(7)
回溯(2)
排序(10)
暑期培訓周賽(3)
數據結構(7)
數論(1)
水題(8)
圖論(24)
網選訓練(8)
隨筆檔案
(127)
2014年3月 (1)
2013年7月 (10)
2013年5月 (1)
2013年4月 (11)
2013年3月 (8)
2012年10月 (1)
2012年9月 (12)
2012年8月 (38)
2012年7月 (14)
2012年6月 (2)
2012年5月 (8)
2012年4月 (6)
2012年3月 (6)
2012年2月 (4)
2011年8月 (5)
friends
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
加油,祝你好運啦!
--小鼠標
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網絡流
過來看看你。
--achiberx
4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調隊列(5493)
2.?Linux select()函數使用(3980)
3.?快速排序、線性時間選擇(3690)
4.?poj3468--絕對經典的線段樹題(3639)
5.?優先隊列--堆實現(3304)
久久青青草视频
|
91精品国产乱码久久久久久
|
久久精品人妻一区二区三区
|
国产精品丝袜久久久久久不卡
|
草草久久久无码国产专区
|
久久久国产一区二区三区
|
午夜人妻久久久久久久久
|
国产激情久久久久影院老熟女免费
|
少妇被又大又粗又爽毛片久久黑人
|
亚洲精品无码久久千人斩
|
色成年激情久久综合
|
一本色道久久99一综合
|
激情综合色综合久久综合
|
久久久久亚洲精品天堂
|
久久强奷乱码老熟女
|
97久久精品午夜一区二区
|
性做久久久久久久久浪潮
|
国产精久久一区二区三区
|
国产亚洲色婷婷久久99精品
|
伊人 久久 精品
|
精品久久久久久无码中文字幕
|
中文字幕热久久久久久久
|
欧美一级久久久久久久大片
|
久久se精品一区精品二区
|
国产69精品久久久久9999APGF
|
国产激情久久久久影院
|
国产一久久香蕉国产线看观看
|
久久国产免费观看精品3
|
精品久久人人爽天天玩人人妻
|
久久精品国产99久久久
|
成人综合久久精品色婷婷
|
亚洲欧洲久久久精品
|
亚洲另类欧美综合久久图片区
|
久久精品99无色码中文字幕
|
欧美激情精品久久久久
|
91久久九九无码成人网站
|
亚洲国产精久久久久久久
|
国产日韩久久久精品影院首页
|
久久精品国产精品亚洲下载
|
国产精品激情综合久久
|
久久久青草青青国产亚洲免观
|