1052 Linked List Sorting (25 分)难度: 一般 / 知识点: 链表
Posted 辉小歌
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1052 Linked List Sorting (25 分)难度: 一般 / 知识点: 链表相关的知识,希望对你有一定的参考价值。
https://pintia.cn/problem-sets/994805342720868352/problems/994805425780670464
哈希表模拟链表。
#include<bits/stdc++.h>
using namespace std;
int n,startx;
vector< pair<int,int> >ans;
unordered_map<int,int>mp,val;
int main(void)
{
cin>>n>>startx;
for(int i=0;i<n;i++)
{
int a,b,c; cin>>a>>b>>c;
val[a]=b,mp[a]=c;
}
while(startx!=-1)
{
ans.push_back({val[startx],startx});
startx=mp[startx];
}
sort(ans.begin(),ans.end());
if(!ans.size())
{
cout<<"0 -1";
return 0;
}
printf("%d %05d\\n",ans.size(),ans[0].second);
for(int i=0;i<ans.size();i++)
{
if(i==ans.size()-1) printf("%05d %d %d\\n",ans[i].second,ans[i].first,-1);
else printf("%05d %d %05d\\n",ans[i].second,ans[i].first,ans[i+1].second);
}
return 0;
}
以上是关于1052 Linked List Sorting (25 分)难度: 一般 / 知识点: 链表的主要内容,如果未能解决你的问题,请参考以下文章
PAT 1052 Linked List Sorting [一般]
1052 Linked List Sorting (25分)
PAT甲级1052 Linked List Sorting (25分)