青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 87  文章 - 279  trackbacks - 0
<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊(cè)

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 221105
  • 排名 - 118

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

BellmanFord實(shí)現(xiàn)

The Doors

Time limit: 1 Seconds?? Memory limit: 32768K??
Total Submit: 214?? Accepted Submit: 63??

You are to find the length of the shortest path through a chamber containing obstructing walls. The chamber will always have sides at x = 0, x = 10, y = 0, and y = 10. The initial and final points of the path are always (0, 5) and (10, 5). There will also be from 0 to 18 vertical walls inside the chamber, each with two doorways. The figure below illustrates such a chamber and also shows the path of minimal length.


Input

The input data for the illustrated chamber would appear as follows.

2
4 2 7 8 9
7 3 4.5 6 7

The first line contains the number of interior walls. Then there is a line for each such wall, containing five real numbers. The first number is the x coordinate of the wall (0 < x < 10), and the remaining four are the y coordinates of the ends of the doorways in that wall. The x coordinates of the walls are in increasing order, and within each line the y coordinates are in increasing order. The input file will contain at least one such set of data. The end of the data comes when the number of walls is -1.


Output

The output file should contain one line of output for each chamber. The line should contain the minimal path length rounded to two decimal places past the decimal point, and always showing the two decimal places past the decimal point. The line should contain no blanks.


Sample Input

1
5 4 6 7 8
2
4 2 7 8 9
7 3 4.5 6 7
-1


Sample Output

10.00
10.06

#include?<iostream>
#include?
<cmath>
using?namespace?std;

const?double?INF?=?2000000000;
const?int?MAXN?=?100;

struct?POINT
{
????
double?x,?y;
}
;
struct?EDGE
{
????
int?u,?v;
}
;

double?g[MAXN][MAXN];
EDGE?e[MAXN
*MAXN];
int?n;
int?i,?j;
double?wX[20];
double?pY[20][4];
double?x;
POINT?p[MAXN];
int?pSize;
int?eSize;

double?Dis(POINT?a,?POINT?b)
{
????
return?sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
}


double?Cross(double?x1,?double?y1,?double?x2,?double?y2,?double?x3,?double?y3)
{
????
return?(x2-x1)*(y3-y1)-(x3-x1)*(y2-y1);
}


bool?IsOk(POINT?a,?POINT?b)
{
????
if?(a.x?>=?b.x)?return?false;
????
int?i,?j;
????
bool?flag?=?true;
????i?
=?0;
????
while?(wX[i]?<=?a.x?&&?i?<?n)?{
????????i
++;
????}

????
while?(wX[i]?<?b.x?&&?i?<?n)?{
????????
if?(Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?0)
????????
*Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?pY[i][0])?<?0
????????
||?Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?pY[i][1])
????????
*Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?pY[i][2])?<?0
????????
||?Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?pY[i][3])
????????
*Cross(a.x,?a.y,?b.x,?b.y,?wX[i],?10)?<?0)?{
????????????flag?
=?false;
????????????
goto?ou;
????????}

????????i
++;
????}

????ou:;
????
return?flag;
}


double?BellmanFord(int?beg,?int?end)
{
????
double?d[MAXN];
????
int?i,?j;
????
for?(i=0;?i<MAXN;?i++)?{
????????d[i]?
=?INF;
????}

????d[beg]?
=?0;
????
bool?ex?=?true;
????
for?(i=0;?i<pSize?&&?ex;?i++)?{
????????ex?
=?false;
????????
for?(j=0;?j<eSize;?j++)?{
????????????
if?(d[e[j].u]?<?INF?&&?d[e[j].v]?>?d[e[j].u]?+?g[e[j].u][e[j].v])?{
????????????????d[e[j].v]?
=?d[e[j].u]?+?g[e[j].u][e[j].v];
????????????????ex?
=?true;
????????????}

????????}

????}

????
return?d[end];
}


void?Solve()
{
????p[
0].x?=?0;
????p[
0].y?=?5;
????pSize?
=?1;
????
for?(i=0;?i<n;?i++)?{
????????scanf(
"%lf",?&wX[i]);
????????
for?(j=0;?j<4;?j++)?{
????????????p[pSize].x?
=?wX[i];
????????????scanf(
"%lf",?&p[pSize].y);
????????????pY[i][j]?
=?p[pSize].y;
????????????pSize
++;
????????}

????}

????p[pSize].x?
=?10;
????p[pSize].y?
=?5;
????pSize
++;
????
for?(i=0;?i<pSize;?i++)?{
????????
for?(j=0;?j<pSize;?j++)?{
????????????g[i][j]?
=?INF;
????????}

????}

????eSize?
=?0;
????
for?(i=0;?i<pSize;?i++)?{
????????
for?(j=i+1;?j<pSize;?j++)?{
????????????
if?(IsOk(p[i],?p[j]))?{
????????????????g[i][j]?
=?Dis(p[i],?p[j]);
????????????????e[eSize].u?
=?i;
????????????????e[eSize].v?
=?j;
????????????????eSize
++;
????????????}

????????}

????}

????printf(
"%.2lf\n",?BellmanFord(0,?pSize-1));
}


int?main()
{
????
while?(scanf("%d",?&n)?!=?EOF)
????
{
????????
if?(n?==?-1)?break;
????????Solve();
????}

????
return?0;
}

posted on 2006-10-09 01:05 閱讀(512) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ACM題目
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美黄免费看| 久久精品国产99| 卡通动漫国产精品| 亚洲在线网站| 亚洲精品乱码视频| 一区二区三区我不卡| 国产精品毛片高清在线完整版| 欧美**字幕| 久久精品视频免费| 性欧美1819性猛交| 国产精品99久久不卡二区 | 午夜在线观看免费一区| 最近中文字幕mv在线一区二区三区四区| 欧美在线free| 亚洲欧美三级伦理| 亚洲一区二区三区三| 亚洲肉体裸体xxxx137| 在线成人激情| 亚洲第一狼人社区| 在线成人www免费观看视频| 国产日韩精品一区| 国产精品视频久久| 国产精品白丝av嫩草影院| 欧美日本二区| 欧美日韩网址| 欧美日韩视频专区在线播放| 欧美精品一区二区三区蜜桃| 欧美本精品男人aⅴ天堂| 老司机精品视频一区二区三区| 久久爱www久久做| 久久精品国产一区二区三区| 欧美一区二区三区电影在线观看| 午夜精品999| 欧美一区二区三区在线观看| 欧美一二三视频| 久久成人18免费观看| 欧美在线国产精品| 久久久久免费视频| 可以看av的网站久久看| 免费成人av在线看| 欧美国产在线观看| 欧美日韩一卡| 国产精品网站在线观看| 国产情侣一区| 精品动漫3d一区二区三区免费版| 亚洲第一黄网| 亚洲毛片在线| 亚洲与欧洲av电影| 欧美永久精品| 米奇777在线欧美播放| 欧美国产日韩精品| 亚洲毛片av在线| 亚洲在线一区二区| 久久国产精品色婷婷| 老司机精品导航| 欧美精品黄色| 国产精品亚洲一区| 精品电影在线观看| 亚洲精品乱码久久久久久蜜桃麻豆 | 国产精品久久久久久久app| 国产精品香蕉在线观看| 国产综合婷婷| 日韩视频不卡中文| 欧美一区免费视频| 欧美大片va欧美在线播放| 亚洲九九精品| 亚洲欧美在线播放| 欧美~级网站不卡| 国产精品日韩欧美大师| 在线免费观看日韩欧美| 中文精品视频一区二区在线观看| 欧美一区二区视频在线观看| 欧美大片免费观看在线观看网站推荐| 亚洲另类视频| 久久久精品2019中文字幕神马| 欧美精品一区在线发布| 国产欧美在线看| 日韩五码在线| 久久久久综合一区二区三区| 亚洲激情二区| 欧美在线免费| 欧美日韩国产系列| 一区二区三区在线看| 国产精品99久久久久久久久| 久久香蕉国产线看观看av| 日韩视频欧美视频| 久热国产精品视频| 国产乱码精品一区二区三区不卡| 亚洲全黄一级网站| 久久久精品性| 在线视频亚洲一区| 欧美91精品| 国外视频精品毛片| 亚洲欧美国产视频| 91久久国产综合久久| 久久精品视频播放| 国产九区一区在线| 亚洲图片欧洲图片日韩av| 免费观看一级特黄欧美大片| 亚洲自拍三区| 欧美日韩国产高清| 亚洲激情偷拍| 欧美在线播放一区| 亚洲社区在线观看| 欧美精品入口| 亚洲精品久久久久| 欧美成熟视频| 久久久蜜桃一区二区人| 国产日韩精品视频一区| 亚洲欧美偷拍卡通变态| 亚洲理伦电影| 欧美日韩成人在线观看| 亚洲精选在线| 欧美激情五月| 久久综合一区二区| …久久精品99久久香蕉国产| 久久精品最新地址| 亚洲欧美激情诱惑| 国产精品一区二区三区乱码| 亚洲综合日韩| 亚洲一区bb| 国产精品久久久一区麻豆最新章节| 在线性视频日韩欧美| 亚洲精品视频在线观看网站 | 国内久久精品| 久久视频在线视频| 久久久久久免费| 在线看一区二区| 免费中文日韩| 美玉足脚交一区二区三区图片| 在线观看中文字幕亚洲| 免费欧美在线视频| 农村妇女精品| 99av国产精品欲麻豆| 99ri日韩精品视频| 国产精品久久一区主播| 午夜宅男欧美| 欧美在线不卡视频| 在线精品在线| 91久久中文| 欧美色中文字幕| 欧美在线精品免播放器视频| 欧美一级夜夜爽| 亚洲高清毛片| 日韩亚洲精品视频| 国产精品毛片va一区二区三区 | 另类春色校园亚洲| 亚洲麻豆av| 亚洲视频第一页| 国产亚洲欧美一区二区三区| 麻豆精品视频在线观看| 欧美丰满少妇xxxbbb| 亚洲制服少妇| 久久精品国产77777蜜臀| 亚洲国产一区二区三区在线播| 亚洲人体偷拍| 国产精品入口夜色视频大尺度| 久久不射2019中文字幕| 久久综合五月天婷婷伊人| 一本一本久久| 欧美在线999| 日韩午夜av电影| 午夜精品久久久久99热蜜桃导演| 精品69视频一区二区三区| 亚洲精品欧美极品| 国产区精品视频| 亚洲国产激情| 国产美女精品视频| 亚洲第一综合天堂另类专| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 性欧美大战久久久久久久久| 亚洲激情欧美激情| 亚洲一区二区三区四区在线观看 | 亚洲欧美激情精品一区二区| 久久久久99| 亚洲欧美国产三级| 模特精品在线| 欧美在线关看| 欧美日韩国产天堂| 麻豆精品一区二区av白丝在线| 欧美日韩黄色大片| 久久综合九色综合欧美就去吻| 欧美日韩亚洲另类| 农村妇女精品| 国产乱码精品一区二区三| 亚洲国产精品免费| 好吊妞这里只有精品| 一区二区黄色| 亚洲精品视频在线播放| 久久成人精品| 午夜精彩国产免费不卡不顿大片| 麻豆av福利av久久av| 久久av二区| 欧美午夜精品久久久久免费视| 欧美成人午夜| 国产一区二区三区自拍| 亚洲手机视频| 一本一本久久a久久精品牛牛影视| 久久久91精品| 欧美在现视频|