1075 鍊錶元素分類 25分

2021-10-06 10:53:14 字數 1712 閱讀 3788

給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 [0, k] 區間內的元素都排在大於 k

的元素前面。但每一類內部元素的順序是不能改變的。例如:給定鍊錶為 18→7→-4→0→5→-6→10→11→-2,k 為 10,則輸出應該為

-4→-6→-2→7→0→5→10→18→11。

輸入格式: 每個輸入包含乙個測試用例。每個測試用例第 1 行給出:第 1 個結點的位址;結點總個數,即正整數n (≤10 ​5 ​​

);以及正整數k (≤10 ​3 ​​ )。結點的位址是 5 位非負整數,null 位址用 −1 表示。

接下來有 n 行,每行格式為:

address data next 其中 address 是結點位址;data 是該結點儲存的資料,為 [−10 ​5 ​​ ,10 ​5

​​ ] 區間內的整數;next 是下一結點的位址。題目保證給出的鍊錶不為空。

輸出格式: 對每個測試用例,按鍊錶從頭到尾的順序輸出重排後的結果鍊錶,其上每個結點佔一行,格式與輸入相同。

輸入樣例:

00100910

23333

1027777

00000

099999

00100

1812309

68237-6

23333

33218-4

00000

48652-2

-199999

568237

27777

1148652

12309

733218

輸出樣例:

33218-4

68237

68237-6

48652

48652-2

12309

12309

700000

00000

099999

99999

523333

23333

1000100

00100

1827777

2777711-

1

思路分析:將結點用list[10000]儲存,list為node型別,node中儲存結點的值value和它的next位址。list的下標就是結點的位址。將<0、0~k,>k三部分的結點分別儲存在vector陣列。最後輸出時要注意格式

#include

#include

using

namespace std;

struct nodelist[

100000];

vector<

int> v[3]

;//儲存三部分資料

intmain()

//分類儲存

int p=start;

while

(p!=-1

)else

if(data>=

0&&data<=k)

else

p=list[p]

.next;

}int flag=0;

for(

int i=

0;i<

3;i++

)else}}

printf

("-1");

return0;

}

參考文章

1075 鍊錶元素分類(25 分)

下次再做一遍 1075 鍊錶元素分類 25 分 給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 0,k 區間內的元素都排在大於 k 的元素前面。但每一類內部元素的順序是不能改變的。例如 給定鍊錶為 18 7 4 0 5 6 10 11 2,k 為 10,...

1075 鍊錶元素分類 (25 分

給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 0,k 區間內的元素都排在大於 k 的元素前面。但每一類內部元素的順序是不能改變的。例如 給定鍊錶為 18 7 4 0 5 6 10 11 2,k 為 10,則輸出應該為 4 6 2 7 0 5 10 18...

1075 鍊錶元素分類 25 分

給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 0,k 區間內的元素都排在大於 k 的元素前面。但每一類內部元素的順序是不能改變的。例如 給定鍊錶為 18 7 4 0 5 6 10 11 2,k 為 10,則輸出應該為 4 6 2 7 0 5 10 18...