PAT乙1075 鍊錶元素分類 。。。

2021-08-21 23:35:55 字數 1553 閱讀 5639

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輸出格式:

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

輸入樣例:

00100910

23333

1027777

00000

099999

00100

1812309

68237 -6

23333

33218 -4

00000

48652 -2 -1

99999

568237

27777

1148652

12309

733218

輸出樣例:

33218 -4

68237

68237 -6

48652

48652 -2

12309

12309

700000

00000

099999

99999

523333

23333

1000100

00100

1827777

27777

11 -1

if(p[i].rk2>0)

}

下面✔

#include

#include

#include

using namespace std;

const int m=1e6;

struct node

p[m];

int s,n,k,a,b,c,to[m],ind[m];

bool cmp(node a,node b)

int st=s,n=0;

while(st!=-1)

sort(p,p+n,cmp);

int j=0,flag=0;

for(int i=0;iif(p[i].rk2>0)////

if(++j==n)break;}}

printf("-1");

return

0;}

PAT乙 1075 鍊錶元素分類

易錯分析 1.可能存在多餘結點,即部分結點即使輸入了,也不在鍊錶中 2.可能存在大於k的陣列不存在元素 解題過程 建立乙個結構體陣列,並用空間換時間的方法,把位址作為下標,值作為結構體物件,其中儲存data和next。通過乙個三維向量儲存屬於不同類的元素,最後輸出即可。程式 include incl...

PAT1075 鍊錶元素分類

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

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