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

posts - 195,  comments - 30,  trackbacks - 0
I have my friends to visit. For some reason, I can only visit some of my friends. So I want see my friends as many as possible. Thus I must choose the longest way. Your goal is to help me developing a program that computes the length of the longest path that can be constructed in a given graph from a given starting point (My residence). You can assume that the graph has no cycles (there is no path from any node to itself), so I will reach my destination in a finite time. In the same line of reasoning, nodes are not considered directly connected to themselves.

Input

The input consists of a number of cases. The first line on each case contains a positive number n (1 < n <= 100) that specifies the number of points in the graph. A value of n = 0 indicates the end of the input. After this, a second number s is provided, indicating the starting point in my journey (1 <= s <= n). Then, you are given a list of pairs of places p and q, one pair per line. The pair "p q" indicates that I can visit q after p. A pair of zeros ("0 0") indicates the end of the case. As mentioned before, you can assume that the graphs provided will not be cyclic.

Output

For each test case you have to find the length of the longest path that begins at the starting place. You also have to print the number of the final place of such longest path. If there are several paths of maximum length, print the final place with smallest number.

Print a new line after each test case.

Sample Input

2
1
1 2
0 0
5
3
1 2
3 5
3 1
2 4
4 5
0 0
5
5
5 1
5 2
5 3
5 4
4 1
4 2
0 0
0

Sample Output

Case 1: The longest path from 1 has length 1, finishing at 2.
Case 2: The longest path from 3 has length 4, finishing at 5.
Case 3: The longest path from 5 has length 2, finishing at 1.
提交了10次,AC 3次,超時(shí)4次,wa 3次。
很無語。
應(yīng)該是動(dòng)態(tài)規(guī)劃最好,但是我不是很熟,用了搜索。以下是超時(shí)的代碼
#include<iostream>
#include<cstdlib>
using namespace std;
int path[101][101];
int mark[101];
int len[101];//
int end[101];
int dfs(int start,int num)//返回從當(dāng)前點(diǎn)出發(fā)的最大長(zhǎng)度
{
if(mark[start]==1)return len[start];
mark[start]=1;
end[start]=start;
for(int i=1;i<=num;i++)
{
if(path[start][i])
{
if(len[start]<dfs(i,num)+1)
{
len[start]=len[i]+1;
end[start]=end[i];
}
else
if(len[start]==len[i]+1&&end[start]>end[i])
end[start]=end[i];
}
}
mark[start]=0;//這句堅(jiān)決不需要 
return len[start];
}
int main()
{
// freopen("s.txt","r",stdin);
//freopen("key.txt","w",stdout);
int j,k,turn=0;
int start,num;
while(cin>>num)
{
turn++;
if(num==0)break;
memset(path,0,sizeof(path));
memset(mark,0,sizeof(mark));
memset(len,0,sizeof(len));
memset(end,0,sizeof(end));
cin>>start;
while(cin>>j>>k)
{
if(j==0)break;
path[j][k]=1;
}
cout<<"Case "<<turn<<": The longest path from "<<start<<" has length "<<dfs(start,num)<<", finishing at "<<end[start]<<"."<<endl<<endl;
}
//system("PAUSE");
return   0;
}
以下是ac的代碼
#include<iostream>
#include<cstdlib>
using namespace std;
int path[102][102];
int mark[102], len[102],end[102];
int dfs(int start,int num)//返回從當(dāng)前點(diǎn)出發(fā)的最大長(zhǎng)度
{
if(mark[start]==1)return len[start];
mark[start]=1;
end[start]=start;
len[start]=0;
int i,t;
for( i=1;i<=num;i++)
{
if(path[start][i])
{
t=dfs(i,num)+1;
if(t>len[start])
{
len[start]=t;
end[start]=end[i];
}
else
if(len[start]==t)
{
if(end[start]>end[i])
end[start]=end[i];
}
}
}
return len[start];
}
int main()
{
//freopen("s.txt","r",stdin);
//freopen("key.txt","w",stdout);
int j,k,turn=0;
int start,num;
while(cin>>num,num)
{
turn++;
memset(path,0,sizeof(path));
memset(mark,0,sizeof(mark));
memset(len,0,sizeof(len));
memset(end,0,sizeof(end));
cin>>start;
while(cin>>j>>k,j||k)
{
path[j][k]=1;
}
dfs(start,num);
cout<<"Case "<<turn<<": The longest path from "<<start<<" has length "<<len[start]<<", finishing at "<<end[start]<<"."<<endl<<endl;
}
//system("PAUSE");
return   0;
}
不妨執(zhí)行一下
5
3
1 2
3 5
3 1
2 4
4 5
0 0
先是len[3]=0;end[3]=3;flag[3]=1;
再執(zhí)行t=dfs(1)+1,
轉(zhuǎn)入dfs(1);len[1]=0;end[1]=1;flag[1]=1;
再執(zhí)行t=dfs(2)+1;
轉(zhuǎn)入dfs(2),len[2]=0;end[2]=2;flag[2]=1;
再執(zhí)行t=dfs(4)+1
轉(zhuǎn)入dfs(4),len[4]=0;end[4]=4;flag[4]=1;
再轉(zhuǎn)入t=dfs(5)+1;
轉(zhuǎn)入dfs(5),len[5]=0;end[5]=5;flag[5]=1;return(len[5]=0);
則t=1;t>len[4];len[4]=1;end[4]=end[5]=5;再看4沒了其他相鄰元素。dfs(4)=return(len[4])=1;
t=dfs(4)+1=2;len[2]=t=2;end[2]=end[4]=5;再看2沒了其他相鄰元素,dfs(2)=return(len(2)=2;
再看t=dfs(2)+1=3;len[1]=t=3;end[1]=en[2]=5;再看1有沒有其他相鄰元素,dfs(1)=return(len(1)=3
再執(zhí)行t=dfs(1)+1,len[3]=4;end[3]=end[1]=5;再看3有沒有其他相鄰元素,有dfs(5),已經(jīng)遍歷到了,所以dfs(5)return len【5】。
沒有影響。
假設(shè)改為
5 3 5 2 3 5 3 1 2 4 4 1 0 0 執(zhí)行時(shí)會(huì)走3->1>這時(shí)的1結(jié)點(diǎn)len[1]已經(jīng)求的 3>5>2>4>1len[1]已知了
posted on 2009-06-29 16:13 luis 閱讀(279) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 搜索給我啟發(fā)題
<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

友情鏈接

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区成人| 最新国产乱人伦偷精品免费网站| 亚洲欧美中文日韩在线| 老牛影视一区二区三区| 欧美大片免费观看| 亚洲欧洲美洲综合色网| 久久精品国产亚洲高清剧情介绍| 欧美午夜精品理论片a级按摩| 亚洲国产欧美不卡在线观看| 西瓜成人精品人成网站| 日韩一区二区电影网| 另类人畜视频在线| 亚洲高清久久| 欧美激情精品久久久| 久久久久久九九九九| 国产日产欧美a一级在线| 午夜精品久久久久久久蜜桃app | 欧美日韩成人在线观看| 亚洲高清一二三区| 蜜臀a∨国产成人精品| 欧美在线免费视屏| 亚洲曰本av电影| 国产欧美激情| 久久深夜福利免费观看| 久久久www成人免费无遮挡大片 | 国产欧美日韩视频在线观看 | 久久久久国色av免费看影院| 性亚洲最疯狂xxxx高清| 国内精品福利| 久久综合狠狠综合久久综合88| 午夜国产不卡在线观看视频| 国产亚洲成精品久久| 久久频这里精品99香蕉| 欧美一级一区| 91久久精品国产91久久性色| 亚洲高清久久久| 蜜桃av一区二区| 亚洲精品国产精品国自产在线| 亚洲国产精品国自产拍av秋霞| 欧美片网站免费| 亚洲女人天堂成人av在线| 亚洲欧美精品| 在线日韩欧美| 91久久国产综合久久蜜月精品 | 亚洲一区二区免费在线| 国产精品一区二区a| 蜜桃久久av一区| 欧美日韩午夜剧场| 久久国产精品99精品国产| 久久婷婷麻豆| 亚洲色图自拍| 欧美在线视频免费播放| 亚洲精品国产精品国产自| 亚洲天堂网在线观看| 在线免费观看日本一区| 欧美精品亚洲二区| 午夜精品一区二区三区四区| 亚洲欧洲av一区二区| 亚洲精品欧美| 亚洲一区二区不卡免费| 亚洲第一视频| 99视频国产精品免费观看| 国产欧亚日韩视频| 91久久视频| 国产自产在线视频一区| 一个人看的www久久| 亚洲第一网站| 久久激情五月婷婷| 亚洲男人的天堂在线观看| 麻豆freexxxx性91精品| 午夜日韩福利| 欧美黄色影院| 麻豆亚洲精品| 国产伦一区二区三区色一情| 亚洲片区在线| 亚洲成在线观看| 欧美有码在线视频| 亚洲欧美日韩国产中文| 欧美黄色网络| 欧美黄色日本| 亚洲电影专区| 欧美一级淫片播放口| 午夜精品在线| 国产精品国产亚洲精品看不卡15| 欧美激情综合| 影音先锋国产精品| 久久久久高清| 久久蜜桃精品| 一区二区三区中文在线观看| 亚洲一区中文| 亚洲综合清纯丝袜自拍| 欧美日韩国产高清| 91久久精品国产91性色| 亚洲日本欧美| 欧美精品一卡二卡| 亚洲人成在线观看一区二区| 亚洲国产乱码最新视频| 久久久99免费视频| 免费不卡在线视频| 好吊视频一区二区三区四区 | 午夜伦理片一区| 午夜久久黄色| 国产日韩欧美电影在线观看| 午夜欧美视频| 久久久噜噜噜久噜久久| 国产一区在线免费观看| 久久精品夜夜夜夜久久| 欧美第一黄网免费网站| 亚洲激情在线观看| 欧美日韩高清一区| 一本久久综合| 午夜精品美女自拍福到在线 | 六月天综合网| 亚洲东热激情| 欧美日韩视频不卡| 制服丝袜亚洲播放| 久久国产精品高清| 影音先锋日韩精品| 欧美a级大片| 亚洲网站视频| 欧美精品123区| 亚洲夜间福利| 久久这里只有| 999在线观看精品免费不卡网站| 欧美日精品一区视频| 亚洲欧美久久| 老司机aⅴ在线精品导航| 夜夜夜久久久| 国产精品丝袜xxxxxxx| 久久躁狠狠躁夜夜爽| 艳女tv在线观看国产一区| 午夜精品福利视频| 影音先锋久久资源网| 欧美日韩99| 欧美一区二区三区婷婷月色 | 久久精品国产99国产精品| 猫咪成人在线观看| 亚洲视频在线观看一区| 国产伦精品一区二区三区| 老司机凹凸av亚洲导航| 中文高清一区| 欧美激情精品久久久久久蜜臀 | 亚洲免费视频中文字幕| 国内精品美女av在线播放| 欧美另类综合| 久久精品亚洲一区二区| 在线亚洲一区观看| 欧美激情一区二区久久久| 午夜视频在线观看一区二区三区| 亚洲国产精品久久精品怡红院| 国产精品久久影院| 欧美激情亚洲激情| 久久久午夜精品| 亚洲图片欧美一区| 亚洲欧洲综合| 麻豆精品一区二区av白丝在线| 亚洲欧美日韩在线播放| 亚洲三级观看| 在线成人国产| 国产一区二区三区视频在线观看| 国产精品久久久久久久9999| 日韩天堂在线视频| 性娇小13――14欧美| 在线观看国产成人av片| 欧美日韩国语| 老司机免费视频一区二区三区| 欧美视频在线一区| 欧美大片在线影院| 欧美一区=区| 亚洲一区国产| 一区二区三区 在线观看视频| 伊人天天综合| 好吊一区二区三区| 国产一区91| 国产女主播一区二区| 国产精品免费一区二区三区在线观看| 欧美成人免费网| 男人插女人欧美| 免费成人av资源网| 麻豆久久婷婷| 免费看成人av| 欧美激情亚洲一区| 欧美精品手机在线| 欧美精品七区| 欧美日韩影院| 国产精品视屏| 国内外成人免费视频| 激情五月综合色婷婷一区二区| 国内精品免费在线观看| 欲香欲色天天天综合和网| 一区一区视频| 欧美黄色一区| 麻豆成人在线播放| 美女精品国产| 欧美黄色精品| 亚洲裸体视频| 中文精品一区二区三区 | 亚洲国产乱码最新视频| 亚洲电影观看| 亚洲看片免费|