5 5 堆中的路徑 25分

2021-07-26 08:52:48 字數 744 閱讀 8024

將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h[i]到根結點的路徑。

每組測試第1行包含2個正整數nn和m

m(\le 1000≤1

000),分別是插入元素的個數、以及需要列印的路徑條數。下一行給出區間[-10000, 10000]內的n

n個要被插入乙個初始為空的小頂堆的整數。最後一行給出m

m個下標。

對輸入中給出的每個下標i,在一行中輸出從h[i]到根結點的路徑上的資料。數字間以1個空格分隔,行末不得有多餘空格。

5 3

46 23 26 24 10

5 4 3

24 23 10

46 23 10

26 10

本題採用的是每讀入乙個數,重新構建一次堆的方法,與stl中algorithm標頭檔案下的make_heap建堆採取的方式不同
#include#includeusing namespace std;

int a[1005]=;

void adjust(int x)

x=y; }}

int main()

for(i=1;i<=m;i++){ //輸出路徑

cin>>j;

while(j!=1){

cout<

PAT 堆中的路徑 25分

2 3 堆中的路徑 25分 將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。每組測試第1行包含2個正整數nn和m m le 1000 1 000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的n n個要被插...

5 6 堆中的路徑 25分

5 6 堆中的路徑 25分 將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。輸入格式 每組測試第1行包含2個正整數nn和mm le 1000 1000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的nn個要...

7 1 堆中的路徑(25 分)

7 1 堆中的路徑 25 分 將一系列給定數字插入乙個初始為空的小頂堆h。隨後對任意給定的下標i,列印從h i 到根結點的路徑。每組測試第1行包含2個正整數n和m 1000 分別是插入元素的個數 以及需要列印的路徑條數。下一行給出區間 10000,10000 內的n個要被插入乙個初始為空的小頂堆的整...