hh 有一串由各種漂亮的貝殼組成的項鍊。hh 相信不同的貝殼會帶來好運,所以每次散步完後,他都會隨意取出一段貝殼,思考它們所表達的含義。hh 不斷地收集新的貝殼,因此,他的項鍊變得越來越長。有一天,他突然提出了乙個問題:某一段貝殼中,包含了多少種不同的貝殼?這個問題很難回答……因為項鍊實在是太長了。於是,他只好求助睿智的你,來解決這個問題。
輸入格式:
第一行:乙個整數n,表示項鍊的長度。
第二行:n 個整數,表示依次表示項鍊中貝殼的編號(編號為0 到1000000 之間的整數)。
第三行:乙個整數m,表示hh 詢問的個數。
接下來m 行:每行兩個整數,l 和r(1 ≤ l ≤ r ≤ n),表示詢問的區間。
輸出格式:
m 行,每行乙個整數,依次表示詢問對應的答案。
輸入樣例#1:
6輸出樣例#1:1 2 3 4 3 5
31 2
3 52 6
2資料範圍:24
對於100%的資料,n <= 500000,m <= 500000。
#include#define n 500005
#define m 1000005
using namespace std;
int n,m,cnt[m],a[n],pos[n],ans=1,ans[n];
struct node
for(int i=1;i<=m;i++) printf("%d\n",ans[i]);
return 0;
}
HH的項鍊(莫隊演算法模版)
include include include include using namespace std int n,m,s int ans 999999 struct stp 999999 int f 999999 a 999999 int cmp const st a,const st b int...
SDOI2009 HH的項鍊 莫隊
hh有一串由各種漂亮的貝殼組成的項鍊。hh相信不同的貝殼會帶來好運,所以每次散步 完後,他都會隨意取出一段貝殼,思考它們所表達的含義。hh不斷地收集新的貝殼,因此,他的項鍊變得越來越長。有一天,他突然提出了乙個問題 某一段貝殼中,包含了多少種不同 的貝殼?這個問題很難回答。因為項鍊實在是太長了。於是...
bzoj1878 HH的項鍊(莫隊)
這篇部落格簡要介紹下我對莫隊的理解。莫隊是一種複雜度為o n sqrt n 的演算法。具體思路是 通過區間左端點的左移和右移與區間右端點的左移和右移來進行更新 排序的時候進行分塊操作,目的是減少左移右移的次數。分塊的話假設序列個數是n,那麼就分為sqrt n 塊,然後根據塊進行排序 就是先將要查詢的...