洛谷P1168 中位數

2022-05-01 05:27:11 字數 976 閱讀 9335

給出乙個長度為n的非負整數序列a[i],對於所有1 ≤ k ≤ (n + 1) / 2,輸出a[1], a[3], …, a[2k - 1]的中位數。即前1,3,5,……個數的中位數。

輸入格式:

輸入檔案median.in的第1行為乙個正整數n,表示了序列長度。

第2行包含n個非負整數a[i] (a[i] ≤ 10^9)。

輸出格式:

輸出檔案median.out包含(n + 1) / 2行,第i行為a[1], a[3], …, a[2i – 1]的中位數。

輸入樣例#1:複製

7

1 3 5 7 9 11 6

輸出樣例#1:複製

135

6

對於20%的資料,n ≤ 100;

對於40%的資料,n ≤ 3000;

對於100%的資料,n ≤ 100000。

權值線段樹;

1 #include2 #include3

const

int maxn=1e5+10;4

intn,m;

5int

s[maxn],d[maxn];

6int t[maxn<<2];7

void add(int k,int l,int r,intx)9

int mid=l+r>>1,ls=k<<1,rs=ls|1;10

if(x<=d[mid]) add(ls,l,mid,x);

11else add(rs,mid+1

,r,x);

12 t[k]=t[ls]+t[rs];13}

14int find(int k,int l,int r,int

x)20

intmain()

29return0;

30 }

洛谷 P1168 中位數

題目描述 給出乙個長度為n的非負整數序列a i 對於所有1 k n 1 2,輸出a 1 a 2 a 2k 1 的中位數。color red 即 color 前1,3,5,個數的中位數。輸入輸出格式 輸入格式 輸入檔案median.in的第1行為乙個正整數n,表示了序列長度。第2行包含n個非負整數a ...

洛谷 P1168 中位數

這個題很簡單 但是我要講3種做法 我們維護乙個小根堆乙個大根堆,其中大根堆的堆頂小於小根堆的所有元素,待加入元素大於大根堆堆頂元素就加入小根堆,反之加入大根堆,然後維護兩個堆元素數量,使得兩個堆的元素數量差為1,這樣我們取兩個堆中元素多的那個的堆頂就是答案 初始化的時候先往大根堆裡加入乙個元素,避免...

洛谷 P1168 中位數

給出乙個長度為n的非負整數序列a i 對於所有1 k n 1 2,輸出a 1 a 3 a 2k 1 的中位數。color red 即 color 前1,3,5,個數的中位數。輸入格式 輸入檔案median.in的第1行為乙個正整數n,表示了序列長度。第2行包含n個非負整數a i a i 10 9 輸...