题目来源
题目描述点击链接自行查看
注意点:
- 链表排序是从给出的那个头结点开始的
思路简介
一开始还在想写一个静态链表的归并排序
然后发现合并的时候不知道怎么复制。。。
后面反应过来发现好像根本不用自己写
把静态链表结点存到数组里面按照k值排序即可
当前地址就是当前地址,下一个地址就是数组排序后的下一个结点存的地址
注意地址补全到五位数
遇到的问题
- 没看懂题目,一开始以为给出的头结点没什么用呢,不过题目里面好像也没说清楚,PAT有的题目描述总是不明不白很难受
代码
cpp
/**
* https://www.nowcoder.com/pat/5/problem/4091
* 模拟
*/
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+8;
struct ListNode{
int curr,k,next;
ListNode():curr(0),k(0),next(0){}
ListNode(int curr,int k,int next):curr(curr),k(k),next(next){}
}List[N];
bool cmp(ListNode *a,ListNode *b){
return a->k<b->k;
}
void solve(){
int n,u;cin>>n>>u;
vector<ListNode*>res;
for(int i=0;i<n;++i){
int curr,k,next;
cin>>curr>>k>>next;
List[curr]=ListNode(curr,k,next);
}
int head=u;
while(head!=-1){
res.emplace_back(&List[head]);
head=List[head].next;
}
sort(res.begin(),res.end(),cmp);
int len=res.size();
if(!len){
cout<<len<<' '<<-1;
return;
}
cout<<len<<' '<<setfill('0')<<setw(5)<<res[0]->curr<<'\n';
for(int i=0;i<len;++i){
cout<<setfill('0')<<setw(5)<<res[i]->curr<<' '<<res[i]->k<<' ';
if(i!=len-1)cout<<setfill('0')<<setw(5)<<res[i+1]->curr<<'\n';
else cout<<-1;
}
}
int main(){
ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
//fstream in("in.txt",ios::in);cin.rdbuf(in.rdbuf());
int T=1;
//cin>>T;
while(T--){
solve();
}
return 0;
}