description
世界盃結束了,義大利人連本帶利的收回了法國人6年前欠他們的債,捧起了大力神盃,成就了4星義大利.
世界盃雖然結束了,但是這界世界盃給我們還是留下許多值得回憶的東西.比如我們聽到了黃名嘴的3分鐘激情解說,我們懂得了原來可以向同乙個人出示3張黃牌,我們還看到了齊達內的頭不僅能頂球還能頂人…………
介於有這麼多的精彩,xhd決定重溫德國世界盃,當然只是去各個承辦世界盃比賽的城市走走看看.但是這需要一大比錢,幸運的是xhd對世界盃的熱愛之情打動了德國世界盃組委會,他們將提供xhd在中國杭州和德國任意世界盃承辦城市的往返機票,並說服了這些城市在xhd到達這座城市時為他提供一筆生活費以便他在那裡參觀時用,當參觀完時剩餘的錢也將留給xhd,但當生活費不夠時他們將強行結束xhd的這次德國之行,除了這個,他們還有乙個條件,xhd只能根據他們所給的路線參觀.比如有3座城市a,b,c,他們給定了a-b-c-a的路線,那麼xhd只有3種參觀順序abc,bca,cab.由於各個城市所提供的生活費和在那裡的花費都不同,這使xhd很頭痛,還好我們事先知道了這筆生活費和花費.請問xhd最多能順利參觀幾座城市?
input
每組輸入資料分兩行,第一行是乙個正整數n(1<=n<=100000),表示有n座城市.接下來的一行按照給定的路線順序的輸出這n個城市的生活費和花費,w1,l1,w2,l2,……,wn,ln,其中wi,li分別表示第i個城市的生活費和花費,並且它們都是正整數.
output
對應每組資料輸出最多能參觀的城市數.
sample input
33 2 3 4 2 2
33 2 3 4 2 3
sample output
32 思路:先做相減的處理,然後就是有點像求序列最長的正整數和
#include #include #include #include using namespace std;
const int maxn = 100005;
int arr[maxn*3];
int n,dp[maxn*3];
int sum[maxn];
int main()
for (int i = 1; i <= n; i++)
arr[i+n] = arr[i];
memset(dp,0,sizeof(dp));
int ans = 0;
sum[0] = 0;
arr[0] = 0;
for (int i = 1; i <= n*2; i++)
else if (arr[i] >= 0 && sum[i-1] < 0)
else
} cout << ans << endl;
} return 0;
}
HDU 1422 重溫世界盃
problem description 世界盃結束了,義大利人連本帶利的收回了法國人6年前欠他們的債,捧起了大力神盃,成就了4星義大利.世界盃雖然結束了,但是這界世界盃給我們還是留下許多值得回憶的東西.比如我們聽到了黃名嘴的3分鐘激情解說,我們懂得了原來可以向同乙個人出示3張黃牌,我們還看到了齊達內...
HDU1422重溫世界盃
其實題目可以理解為 給出迴圈數字序列,找出最長的和不為負數的子串行,輸出該子串行的長度。include include include using namespace std int main else if sum 0 max temp max temp max cout max endl ret...
HDU 1422 重溫世界盃
題目中說只需按照所給順序,不論起點,輸出能連續旅遊的最多的城市 就是不論起點這句,我就卡住了。看了別人的題解,迴圈個2n 1次便是把所有的起點都考慮進去了。更詳細的解釋在 的注釋裡。1 define local 2 include 3 include 4 include 5 using namesp...