PAT乙級 1075 鍊錶元素分類 25 分

2021-10-25 16:04:03 字數 2287 閱讀 1122

給定乙個單鏈表,請編寫程式將鍊錶元素進行分類排列,使得所有負值元素都排在非負值元素的前面,而 [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≤10^5

≤105

);以及正整數k (≤10

3≤10^3

≤103

)。結點的位址是 5 位非負整數,null 位址用 −1−1

−1表示。

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

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

−5,1

05

][10^,10^5]

[10−5,

105]

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

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

#include

using

namespace std;

// 鍊錶節點

const

int maxn =

1e6+10;

struct node nod[maxn]

;int

main()

// 裝入向量

vector list1;

for(head1; head1 !=-1

; head1 = nod[head1]

.next)

list1.

push_back

(nod[head1]);

// 分類儲存

vector v[3]

;int sum = list1.

size()

;for

(int i =

0; i < sum; i++

)// 按類分發

vector list2;

for(

int i =

0; i <

3; i++

) list2.

insert

(list2.

end(

), v[i]

.begin()

, v[i]

.end()

);// 更新下標

for(

int i =

0; i < sum -

1; i++

) list2[i]

.next = list2[i+1]

.address;

list2[sum-1]

.next =-1

;// 格式化列印

for(

int i =

0; i < sum -

1; i++

)printf

("%05d %d %05d\n"

, list2[i]

.address, list2[i]

.key, list2[i]

.next)

;printf

("%05d %d -1\n"

, list2[sum-1]

.address, list2[sum-1]

.key)

;return0;

}

PAT 乙級 1075 鍊錶元素分類 25

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 ...

PAT乙級1075 鍊錶元素分類 Cpp

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

PAT乙級 1075 鍊錶元素分類 25分

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