PAT甲级-1052 Linked List Sorting

题目

题目大意

给定一个链表,要求按链表中的数值从小到大排序生成新的链表。输出有效节点的个数和链表的起始地址,以及链表本身。

思路

链表用结构体数组来表示,然后用sort自定义排序。需要注意的是,链表中存在无效节点,因此需要遍历一遍链表,将有效的节点筛选出来。同时也要注意格式化输出(测试点3是链表首地址格式化输出)。测试点4是当没有有效节点时,要输出0 -1。

代码

cpp 复制代码
#include <iostream>
#include <algorithm>
using namespace std;

struct node{
    int now;  // 当前节点的地址
    int key;  // 节点值
    int next;  // 下一个节点的地址
}v[100000];
int n, s;

bool cmp(node x, node y){
    return x.key < y.key;
}

int main(){
    cin >> n >> s;
    for (int i = 0; i < n; i++){
        int ads;
        cin >> ads;
        v[ads].now = ads;
        cin >> v[ads].key >> v[ads].next;
    }

    vector<node> res;  // 记录有效链表的节点
    for (int i = s; i != -1; i = v[i].next){
        res.push_back(v[i]);
    }

    sort(res.begin(), res.end(), cmp);
    if (!(int)res.size()){
        cout << "0 -1" << endl;  //测试点4
        return 0;
    }
    printf("%d %05d\n", (int)res.size(), res[0].now);  // 测试点3,首地址也要格式化输出
    for (int i = 0; i < (int)res.size(); i++){
        printf("%05d %d ", res[i].now, res[i].key);  // 注意要格式化输出
        if (i == (int)res.size() - 1){
            printf("-1\n");
        }else{
            printf("%05d\n", res[i + 1].now);
        }
    }

    return 0;
}
相关推荐
代码改善世界4 小时前
【数据结构与算法】栈和队列题解
数据结构
ShineWinsu4 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承
消失的旧时光-19435 小时前
C++ 多线程与并发系统取向(二)—— 资源保护:std::mutex 与 RAII(类比 Java synchronized)
java·开发语言·c++·并发
抓饼先生7 小时前
iceoryx编译和验证
linux·c++·零拷贝·iceoryx
王老师青少年编程7 小时前
2020年信奥赛C++提高组csp-s初赛真题及答案解析(阅读程序第2题)
c++·题解·真题·初赛·信奥赛·csp-s·提高组
你的冰西瓜8 小时前
C++ STL算法——排序和相关操作
开发语言·c++·算法·stl
今儿敲了吗8 小时前
29| 高考志愿
c++·笔记·学习·算法
浅念-9 小时前
C++ 模板进阶
开发语言·数据结构·c++·经验分享·笔记·学习·模版
紫陌涵光9 小时前
77. 组合
c++·算法·leetcode·深度优先
We་ct10 小时前
LeetCode 222. 完全二叉树的节点个数:两种解法详解(BFS + 二分查找优化)
数据结构·算法·leetcode·typescript