小明這些天一直在思考這樣乙個奇怪而有趣的問題:
在1~n的某個全排列中有多少個連號區間呢?這裡所說的連號區間的定義是:
如果區間[l, r] 裡的所有元素(即此排列的第l個到第r個元素)遞增排序後能得到乙個長度為r-l+1的「連續」數列,則稱這個區間連號區間。
當n很小的時候,小明可以很快地算出答案,但是當n變大的時候,問題就不是那麼簡單了,現在小明需要你的幫助。
輸入格式:
第一行是乙個正整數n (1 <= n <= 50000), 表示全排列的規模。
第二行是n個不同的數字pi(1 <= pi <= n), 表示這n個數字的某一全排列。
輸出格式:
輸出乙個整數,表示不同連號區間的數目。
示例:使用者輸入:
43 2 4 1
程式應輸出:
7使用者輸入:
53 4 2 5 1
程式應輸出:
9解釋:
第乙個用例中,有7個連號區間分別是:[1,1], [1,2], [1,3], [1,4], [2,2], [3,3], [4,4]
第二個用例中,有9個連號區間分別是:[1,1], [1,2], [1,3], [1,4], [1,5], [2,2], [3,3], [4,4], [5,5]
資源約定:
峰值記憶體消耗 < 64m
cpu消耗 < 5000ms
請嚴格按要求輸出,不要畫蛇添足地列印類似:「請您輸入...」 的多餘內容。
所有**放在同乙個原始檔中,除錯通過後,拷貝提交該原始碼。
注意: main函式需要返回0
注意: 只使用ansi c/ansi c++ 標準,不要呼叫依賴於編譯環境或作業系統的特殊函式。
注意: 所有依賴的函式必須明確地在原始檔中 #include , 不能通過工程設定而省略常用標頭檔案。
提交時,注意選擇所期望的編譯器型別。
思路:
通過暴力方法可以解決此題,複雜度大約在n*n,可能超時。
理解連號區間,通過遍歷所有區間,計算是否符合連號區間特徵(可以通過在[l, r]中max(最大元素值) - min(最小元素值) == j - i 即可判斷是否是連號區間)。
**如下:
#include#include#includeusing namespace std;
int a[50001];
int main()
for (int i = 0; i < n; i++)
else
}} cout << ans;
return 0;
}
藍橋杯歷屆試題 連號區間數 暴力
問題描述 小明這些天一直在思考這樣乙個奇怪而有趣的問題 在1 n的某個全排列中有多少個連號區間呢?這裡所說的連號區間的定義是 如果區間 l,r 裡的所有元素 即此排列的第l個到第r個元素 遞增排序後能得到乙個長度為r l 1的 連續 數列,則稱這個區間連號區間。當n很小的時候,小明可以很快地算出答案...
藍橋杯 歷屆試題 連號區間數 暴力
時間限制 1.0s 記憶體限制 256.0mb 小明這些天一直在思考這樣乙個奇怪而有趣的問題 在1 n的某個全排列中有多少個連號區間呢?這裡所說的連號區間的定義是 如果區間 l,r 裡的所有元素 即此排列的第l個到第r個元素 遞增排序後能得到乙個長度為r l 1的 連續 數列,則稱這個區間連號區間。...
藍橋杯 歷屆試題 連號區間數
問題描述 小明這些天一直在思考這樣乙個奇怪而有趣的問題 在1 n的某個全排列中有多少個連號區間呢?這裡所說的連號區間的定義是 如果區間 l,r 裡的所有元素 即此排列的第l個到第r個元素 遞增排序後能得到乙個長度為r l 1的 連續 數列,則稱這個區間連號區間。當n很小的時候,小明可以很快地算出答案...