1075 鍊錶元素分類 25

2021-08-10 22:10:05 字數 1387 閱讀 3294

1075. 鍊錶元素分類(25)題目

給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而[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行給出:第1個結點的位址;結點總個數,即正整數n (<= 105);以及正整數k (<=1000)。結點的位址是5位非負整數,null位址用-1表示。

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

address data next

輸出格式:

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

輸入樣例:

00100 9 10

23333 10 27777

00000 0 99999

00100 18 12309

68237 -6 23333

33218 -4 00000

48652 -2 -1

99999 5 68237

27777 11 48652

12309 7 33218

輸出樣例:

33218 -4 68237

68237 -6 48652

48652 -2 12309

12309 7 00000

00000 0 99999

99999 5 23333

23333 10 00100

00100 18 27777

27777 11 -1思路

陣列下標代表位址,兩個陣列分別儲存資料和下乙個位址,然後分成三類,先把值小於零的不改順序輸出,然後是大於零小於k的,最後是大於k的。最後輸出的時候,輸出下乙個位址,是在下一次迴圈中輸出的當前位址,因為分類之後中間的數可能跳過了,所以下乙個位址應該等找到下乙個滿足的數才取它的位址。(不再是原來的next存的值了)。

**

#include 

struct lnode

node[100000];

int main(void)

for(i = 0; i < 3; i++)

for(a = fa; a != -1; a = node[a].next)

if((i == 0 && node[a].data < 0)||(i == 1 && node[a].data >= 0 &&node[a].data <= k)||(i == 2 && node[a].data > k))

printf("-1");

return

0;}

1075 鍊錶元素分類 25

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

1075 鍊錶元素分類 25

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

1075 鍊錶元素分類 25

時間限制 400 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 0,k 區間內的元素都排在大於k的元素前面。但每一類內部元素的順序是不能改變...