每組測試第1行包含2個正整數n和
m(≤1
000),分別是插入元素的個數、以及需要列印的路徑條數。下一行給出區間[-10000, 10000]內的
n個要被插入乙個初始為空的小頂堆的整數。最後一行給出
m個下標。
對輸入中給出的每個下標i
,在一行中輸出從h[i]
到根結點的路徑上的資料。數字間以1個空格分隔,行末不得有多餘空格。
5 3
46 23 26 24 10
5 4 3
24 23 10
46 23 10
26 10
題解:
#include#define mod 1000000007
const int inf = 0x7f7f7f7f;
typedef long long ll;
using namespace std;
struct heap
;void insert(heap *h, int n)
int i = ++h->size;
for(; h->data[i/2]>n; i/=2)
h->data[i] = h->data[i/2];
h->data[i] = n;
}int main()
while(t--)
else
}printf("\n");
}return 0;
}
05 樹7 堆中的路徑
將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。每組測試第1行包含2個正整數n和m 1000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的n個要被插入乙個初始為空的小頂堆的整數。最後一行給出m個下標。對輸...
05 樹7 堆中的路徑
將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。每組測試第1行包含2個正整數n和m 1000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的n個要被插入乙個初始為空的小頂堆的整數。最後一行給出m個下標。對輸...
05 樹7 堆中的路徑 25分
05 樹7 堆中的路徑 25分 將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。每組測試第1行包含2個正整數nn和m m 1000 1 000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的n n個要被插入...