【PAT甲级真题】- Linked List Sorting (25)

题目来源

Linked List Sorting (25)

题目描述点击链接自行查看

注意点:

  • 链表排序是从给出的那个头结点开始的

思路简介

一开始还在想写一个静态链表的归并排序

然后发现合并的时候不知道怎么复制。。。

后面反应过来发现好像根本不用自己写

把静态链表结点存到数组里面按照k值排序即可

当前地址就是当前地址,下一个地址就是数组排序后的下一个结点存的地址

注意地址补全到五位数

遇到的问题

  1. 没看懂题目,一开始以为给出的头结点没什么用呢,不过题目里面好像也没说清楚,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;
}
相关推荐
kisshyshy10 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
众少成多积小致巨12 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
猿人谷17 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络19 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络19 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao40019 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao40019 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法