根據題意分三步走 :遍歷鍊錶,①將遇到的負數的下標記錄在out1陣列中 ;
②將遇到【0,k】內的鍊錶元素的下標記錄在out2陣列中;
③將其他元素的下標記錄在out3陣列中 ;
最後按out1,out2,out3陣列下標輸出鍊錶元素即可。
注意點:輸出格式(詳見**)。
給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 [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 (≤105);以及正整數k (≤103)。結點的位址是 5 位非負整數,null 位址用 −1 表示。
接下來有 n 行,每行格式為:
其中address data next
address
是結點位址;data
是該結點儲存的資料,為 [−105,105] 區間內的整數;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
/***************2019.6.20-13:05-13:25(完成思想)**************/
/***************2019.6.21-12:40-13:28(實現中)**************/
/***************2019.6.22-12:40-12:54(fininshed)**************/
//b1075 鍊錶元素分類 1.2h
//演算法思想: 根據題意分三步走 :遍歷鍊錶,①將遇到的負數的下標記錄在out1陣列中 ;
// ②將遇到【0,k】內的鍊錶元素的下標記錄在out2陣列中;
// ③將其他元素的下標記錄在out3陣列中 ;
// 最後按out1,out2,out3陣列下標輸出即可。
#include//typedef struct node *listnode;
struct nodelist[100000];
int main()while(a!=-1);
for(i=0;ifor(i=0;ifor(i=0;iprintf("-1\n");
return 0;
}
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,則輸出應該為 ...
PAT B1075 鍊錶元素分類 (25 分
1075 鍊錶元素分類 25 分 給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 0,k 區間內的元素都排在大於 k 的元素前面。但每一類內部元素的順序是不能改變的。例如 給定鍊錶為 18 7 4 0 5 6 10 11 2,k 為 10,則輸出應該為 ...