description
很多學校流行一種比較的習慣。老師們很喜歡詢問,從某某到某某當中,分數最高的是多少。
這讓很多學生很反感。
不管你喜不喜歡,現在需要你做的是,就是按照老師的要求,寫乙個程式,模擬老師的詢問。當然,老師有時候需要更新某位同學的成績。
input
本題目包含多組測試,請處理到檔案結束。
在每個測試的第一行,有兩個正整數 n 和 m ( 0
output
對於每一次詢問操作,在一行裡面輸出最高成績。
sample input
5 61 2 3 4 5
q 1 5
u 3 6
q 3 4
q 4 5
u 2 9
q 1 5
sample output
5659
hint
huge input,the c function scanf() will work better than cin
線段樹模板題
#include #includeusing namespace std;const int n=2000005;struct nodetree[n];int ans;int max(int a,int b)void build(int k,int ll,int rr) int mid=(ll+rr)/2; build(2*k,ll,mid); build(2*k+1,mid+1,rr); tree[k].weight=max(tree[2*k].weight,tree[2*k+1].weight);}void ask_interval(int k,int a,int b) int mid=(tree[k].left+tree[k].right)/2; if(a<=mid) ask_interval(2*k,a,b); if(b>mid) ask_interval(2*k+1,a,b);}void change_point(int k,int x,int f) int
mid=(tree[k].left+tree[k].right)/2; if(x<=mid) change_point(2*k,x,f); if(x>mid) change_point(2*k+1,x,f); tree[k].weight=max(tree[2*k].weight,tree[2*k+1].weight);}int main() if(c=='u') change_point(1,u,v); } } return 0;}
HDU 1754 I Hate It(單點更新)
很水的線段樹,單點更新 rmq更快 include includeint n int in 200010 struct treetree 540000 int max int a,int b void build int s,int t,int id int mid s t 1 build s,mi...
hdu 1754 I Hate It 樹狀陣列
小記 對於求區間的最值問題,如何利用樹狀陣列來解決它 idx i 表示1 i區間中最大的值,a是存放元素陣列 利用樹狀陣列來求解區間最值問題的原理就是樹狀陣列對二進位制的利用,對於樹狀陣列的第k個陣列元素值它的意義代表著區間 k lowbit k 1,k 的最大值,在它的下面有lowbit k 個類...
hdu 1754 I Hate It (線段樹版)
讀入的時候因為要先輸入字元c,所以要用getchar 和輸入時的 c處理掉空格,很煩,不按字元輸入而是 s輸入字串可避免這個問題 include include using namespace std define lson l,m,rt 1 define rson m 1,r,rt 1 1 def...