HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯(lián)系
管理
poj2253--最短路Dijkstra
題意描述:
公青蛙a要找到母青蛙b,他要跳過若干塊石頭到達(dá)b處,他并不關(guān)心走過總路程的長短,但是希望單次跳動的長度最短。
最短路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
小鼠標(biāo)
閱讀(129)
評論(0)
編輯
收藏
引用
所屬分類:
圖論
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
hdu3549--網(wǎng)絡(luò)流
poj1273--網(wǎng)絡(luò)流
hdu3118Arbiter
poj2488--回溯
poj2386--圖的遍歷
hdu3342--拓?fù)渑判?/a>
hdu1285--拓?fù)渑判?/a>
zoj1060,poj1094--拓?fù)渑判?/a>
poj1135--Dijkstra
poj3268--Dijkstra
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標(biāo) 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基礎(chǔ)練習(xí)(25)
安卓(1)
本科畢設(shè)(1)
博弈(1)
大數(shù)(7)
回溯(2)
排序(10)
暑期培訓(xùn)周賽(3)
數(shù)據(jù)結(jié)構(gòu)(7)
數(shù)論(1)
水題(8)
圖論(24)
網(wǎng)選訓(xùn)練(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
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學(xué)長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準(zhǔn)真的不是自己的原因呢。
加油,祝你好運(yùn)啦!
--小鼠標(biāo)
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網(wǎng)絡(luò)流
過來看看你。
--achiberx
4.?re: (轉(zhuǎn))ubuntu11.10無法啟動無線網(wǎng)絡(luò)的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區(qū)域賽難道是ACM區(qū)域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區(qū)基準(zhǔn)在數(shù)組中重復(fù)的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調(diào)隊列(5492)
2.?Linux select()函數(shù)使用(3979)
3.?快速排序、線性時間選擇(3689)
4.?poj3468--絕對經(jīng)典的線段樹題(3638)
5.?優(yōu)先隊列--堆實現(xiàn)(3304)
久久夜色精品国产亚洲
|
久久午夜电影网
|
99久久伊人精品综合观看
|
亚洲国产成人久久综合碰碰动漫3d
|
狠狠人妻久久久久久综合蜜桃
|
三级韩国一区久久二区综合
|
国产精品免费久久久久久久久
|
中文字幕无码av激情不卡久久
|
国产一区二区三区久久精品
|
四虎影视久久久免费
|
99国产精品久久
|
亚洲午夜久久久久久久久久
|
91久久精品91久久性色
|
亚洲欧洲精品成人久久奇米网
|
久久精品免费全国观看国产
|
久久人妻少妇嫩草AV蜜桃
|
狠狠精品久久久无码中文字幕
|
久久精品国产精品亚洲艾草网美妙
|
久久99精品久久久久久野外
|
久久99精品国产麻豆婷婷
|
久久天天躁狠狠躁夜夜2020老熟妇
|
亚洲欧美久久久久9999
|
久久久久久亚洲精品成人
|
久久久久无码精品国产
|
国内精品伊人久久久久av一坑
|
2022年国产精品久久久久
|
国内精品欧美久久精品
|
97香蕉久久夜色精品国产
|
色综合久久无码五十路人妻
|
青青青国产成人久久111网站
|
久久国产精品国语对白
|
亚洲中文字幕无码久久2017
|
久久99精品久久久久久
|
久久笫一福利免费导航
|
狠狠色丁香久久婷婷综合五月
|
99热成人精品免费久久
|
久久经典免费视频
|
日本福利片国产午夜久久
|
久久午夜夜伦鲁鲁片免费无码影视
|
大伊人青草狠狠久久
|
亚洲va久久久久
|