老管家是乙個聰明能幹的人。他為財主工作了整整10年,財主為了讓自已賬目更加清楚。要求管家每天記k次賬,由於管家聰明能幹,因而管家總是讓財主十分滿意。但是由於一些人的挑撥,財主還是對管家產生了懷疑。於是他決定用一種特別的方法來判斷管家的忠誠,他把每次的賬目按1,2,3…編號,然後不定時的問管家問題,問題是這樣的:在a到b號賬中最少的一筆是多少?為了讓管家沒時間作假他總是一次問多個問題。
輸入格式:
輸入中第一行有兩個數m,n表示有m(m<=100000)筆賬,n表示有n個問題,n<=100000。
第二行為m個數,分別是賬目的錢數
後面n行分別是n個問題,每行有2個數字說明開始結束的賬目編號。
輸出格式:
輸出檔案中為每個問題的答案。具體檢視樣例。
輸入樣例#1:
10 31 2 3 4 5 6 7 8 9 10
2 73 9
1 10
輸出樣例#1:
2 3 1
典型的rmq問題,然而不會st表。。。
直接線段樹。。。
附**:
#include#include#include#define lson rt<<1
#define rson rt<<1|1
#define data(x) a[x].data
#define lside(x) a[x].l
#define rside(x) a[x].r
#define width(x) (rside(x)-lside(x)+1)
#define maxn 100010
using namespace std;
int m,n;
struct nodea[maxn<<2];
inline int read()
while(c>='0'&&c<='9')
return date*w;
}void pushup(int rt)
void buildtree(int l,int r,int rt)
mid=l+r>>1;
buildtree(l,mid,lson);
buildtree(mid+1,r,rson);
pushup(rt);
}long long query(int l,int r,int rt)
int main()
cout
}
洛谷P1816 忠誠 分塊
分塊真的是很暴力呀 暴力查詢左端,暴力查詢又端點,中間整體部分直接 o 1 求出。注意程式設計細節 belong i i 1 block 1 這樣可以保證序列被分成這樣的 code include include include includeusing namespace std const in...
倍增 rmq 忠誠 洛谷P1816
老管家是乙個聰明能幹的人。他為財主工作了整整10年,財主為了讓自已賬目更加清楚。要求管家每天記k次賬,由於管家聰明能幹,因而管家總是讓財主十分滿意。但是由於一些人的挑撥,財主還是對管家產生了懷疑。於是他決定用一種特別的方法來判斷管家的忠誠,他把每次的賬目按1,2,3 編號,然後不定時的問管家問題,問...
洛谷P1816 忠誠 線段樹
老管家是乙個聰明能幹的人。他為財主工作了整整10年,財主為了讓自已賬目更加清楚。要求管家每天記k次賬,由於管家聰明能幹,因而管家總是讓財主十分滿意。但是由於一些人的挑撥,財主還是對管家產生了懷疑。於是他決定用一種特別的方法來判斷管家的忠誠,他把每次的賬目按1,2,3 編號,然後不定時的問管家問題,問...