洛谷1137 旅行計畫

2021-08-10 02:12:18 字數 1054 閱讀 9406

題目描述

小明要去乙個國家旅遊。這個國家有n個城市,編號為1~n,並且有m條道路連線著,小明準備從其中乙個城市出發,並只往東走到城市i停止。

所以他就需要選擇最先到達的城市,並制定一條路線以城市i為終點,使得線路上除了第乙個城市,每個城市都在路線前乙個城市東面,並且滿足這個前提下還希望遊覽的城市盡量多。

現在,你只知道每一條道路所連線的兩個城市的相對位置關係,但並不知道所有城市具體的位置。現在對於所有的i,都需要你為小明制定一條路線,並求出以城市i為終點最多能夠遊覽多少個城市。

輸入格式:

輸入的第1行為兩個正整數n, m。

接下來m行,每行兩個正整數x, y,表示了有一條連線城市x與城市y的道路,保證了城市x在城市y西面。

輸出格式:

輸出包括n行,第i行包含乙個正整數,表示以第i個城市為終點最多能遊覽多少個城市。

對於dag上的dp,建反圖然後拓撲排序dp

#include

using

namespace

std;

const

int maxn=100005;

int head[maxn],cnt=0,inde[maxn],dp[maxn];

struct edgee[maxn<<1];

inline

void add(int u,int v),head[u]=cnt;}

int n,m;

queue

q;vector

vec;

void topsort()

}while(!q.empty())}}

}int main()

topsort();

// for(int i=0;iint la=vec.size()-1;

for(int i=1;i<=n;i++)dp[i]=1;

for(int i=la-1;i>=0;i--)

}for(int i=1;i<=n;i++)printf("%d\n",dp[i]);

return

0;}

洛谷1137 旅行計畫

小明要去乙個國家旅遊。這個國家有n個城市,編號為1 n,並且有m條道路連線著,小明準備從其中乙個城市出發,並只往東走到城市i停止。所以他就需要選擇最先到達的城市,並制定一條路線以城市i為終點,使得線路上除了第乙個城市,每個城市都在路線前乙個城市東面,並且滿足這個前提下還希望遊覽的城市盡量多。現在,你...

洛谷 P1137 旅行計畫

題目描述 小明要去乙個國家旅遊。這個國家有n個城市,編號為1 n,並且有m條道路連線著,小明準備從其中乙個城市出發,並只往東走到城市i停止。所以他就需要選擇最先到達的城市,並制定一條路線以城市i為終點,使得線路上除了第乙個城市,每個城市都在路線前乙個城市東面,並且滿足這個前提下還希望遊覽的城市盡量多...

洛谷P1137 旅行計畫

題目描述 小明要去乙個國家旅遊。這個國家有n個城市,編號為1 n,並且有m條道路連線著,小明準備從其中乙個城市出發,並只往東走到城市i停止。所以他就需要選擇最先到達的城市,並制定一條路線以城市i為終點,使得線路上除了第乙個城市,每個城市都在路線前乙個城市東面,並且滿足這個前提下還希望遊覽的城市盡量多...