当前位置: 首页 > article >正文

PAT甲级-1052 Linked List Sorting

题目

题目大意

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

思路

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

代码

#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;
}


http://www.kler.cn/a/376813.html

相关文章:

  • Rust 力扣 - 1423. 可获得的最大点数
  • Linux:网络协议socket
  • 物联网赋能的人工智能图像检测系统
  • IsADirectoryError: [Errno 21] Is a directory: ‘xxxxx/.ipynb_checkpoints‘
  • python 获取鼠标点击的实时位置案例
  • IMU应用于监测进食
  • #渗透测试#SRC漏洞挖掘# 信息收集-Shodan进阶之Mongodb未授权访问
  • sql进阶篇
  • 华为云安装docker
  • GNSS和PTP时间同步的基础原理介绍
  • Android 百度面经
  • Golang反射原理
  • 问:Redis常见性能问题及解法?
  • LeetCode每日一题3226---使两个整数相等的位更改次数
  • C#WPF使用CommunityToolkit.Mvvm库
  • jmeter基础01-1_环境准备-windows系统安装jdk
  • 基本查询【MySQL】
  • token无感刷新+处理并发的后端方案
  • Vue3+TypeScript+Vite 后台管理项目_登录页面开发实战
  • 项目实战:基于Linux的Flappy bird游戏开发
  • 第二届开放原子大赛-开源工业软件算法集成大赛即将启动!
  • 网络基础知识概览
  • 贪心算法习题其三【力扣】【算法学习day.20】
  • angular登录按钮输入框监听
  • Python 定时调度任务
  • nignx代理获取真实地址request.getRequestURL()