計蒜客 管家的忠誠 線段樹

2021-08-06 06:23:10 字數 1073 閱讀 4658

老管家是乙個聰明能幹的人。他為財主工作了整整10年,財主為了讓自已賬目更加清楚。要求管家每天記k次賬,由於管家聰明能幹,因而管家總是讓財主十分滿意。但是由於一些人的挑撥,財主還是對管家產生了懷疑。於是他決定用一種特別的方法來判斷管家的忠誠,他把每次的賬目按1,2,3…編號,然後不定時的問管家問題,問題是這樣的:在a到b號賬中最少的一筆是多少?為了讓管家沒時間作假他總是一次問多個問題。

輸入中第一行有兩個數m,n表示有m(m< =100000)筆賬,n表示有n個問題,n< =100000。 第二行為m個數,分別是賬目的錢數 後面n行分別是n個問題,每行有2個數字說明開始結束的賬目編號。

輸出檔案中為每個問題的答案。具體檢視樣例。

樣例輸入

10 3

1 2 3 4 5 6 7 8 9 10

2 73 9

1 10

樣例輸出

2 3 1

#include#includeusing namespace std;  

#define maxn 200005

int ans;

struct node

}tr[maxn*4];

void buildtree(int l,int r,int i)

int mid = tr[i].mid();

buildtree(l,mid,i<<1);

buildtree(mid+1,r,i<<1|1);

tr[i].minn = min(tr[i<<1].minn,tr[i<<1|1].minn);

}

void query(int l,int r,int i,int l,int r)

int mid = tr[i].mid();

if(r<=mid) query(l,mid,i<<1,l,r);

else if(l>mid) query(mid+1,r,i<<1|1,l,r);

else

}

int main()

} return 0;

}

計蒜客 硬幣翻轉 線段樹

原題鏈結 線段樹,每個節點儲存的資訊 左端點正面向上的最大長度和反面向上的最大長度,右端點正面向上的最大長度 和反面向上的最大長度 該區間正面向上的最大長度 和反面向上的最大長度 當然這裡的最大長度是連續的。lazy標記表示其子節點是否需要更新。struct nodet maxn ac includ...

問題 H 老管家的忠誠(線段樹)

時間限制 0 sec 記憶體限制 128 mb 提交 54 解決 21 提交 狀態 討論版 命題人 外部匯入 老管家是乙個聰明能幹的人。他為財主工作了整整10年,財主為了讓自已賬目更加清楚。要求管家每天記k次賬,由於管家聰明能幹,因而管家總是讓財主十分滿意。但是由於一些人的挑撥,財主還是對管家產生了...

計蒜客 樹狀陣列線段樹 帕吉的肉鉤

分析題意,是一道典型的線段樹題目.要求做到區間賦值 樹狀陣列應該無法做到 區間求和兩個操作.開始的時候思路不清楚,後來要注意線段樹的 up 和 down 操作.需要注意的是有lazy tag的節點,它本身的資訊是完全正確的,子節點的資訊是待更新的.這也就是說,當需要用到這些子節點的資訊時在進行更新....