PAT B1075 鍊錶元素分類 (25 分

2021-09-19 12:21:42 字數 1768 閱讀 3285

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 個結點的位址;結點總個數,即正整數n (≤10​5​​);以及正整數k (≤10​3​​)。結點的位址是 5 位非負整數,null 位址用 −1 表示。

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

address data next
其中address是結點位址;data是該結點儲存的資料,為 [−10​5​​,10​5​​] 區間內的整數;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

兩種方法**一樣長:推薦第二種。

#include #include using namespace std;

int main()

int valid = 0;

while(first != -1)

int cnt = 0;

for(int i = 0; i < valid; i++)

for(int i = 0; i < valid; i++)

for(int i = 0; i < valid; i++)

for(int i = 0; i < valid; i++)

printf("\n");

return 0;

}

這樣最後乙個-1沒有被%05d輸出,迴圈結束後補上一行輸出 -1。(為什麼?-1被%05d輸出是-00001,就錯了,應是-1)。

#include #include using namespace std;

struct nodelist[100000];

vectorv[3];

int main()

int p = first, flag = 0;

while(p != -1)

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

} }printf("-1");

return 0;

}

PAT B1075 鍊錶元素分類

根據題意分三步走 遍歷鍊錶,將遇到的負數的下標記錄在out1陣列中 將遇到 0,k 內的鍊錶元素的下標記錄在out2陣列中 將其他元素的下標記錄在out3陣列中 最後按out1,out2,out3陣列下標輸出鍊錶元素即可。注意點 輸出格式 詳見 給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得...

PAT B1075 鍊錶分類

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

PAT B1075 鍊錶元素分類(25 分)

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