zoukankan      html  css  js  c++  java
  • 1075. 链表元素分类(25)

    1075. 链表元素分类(25)

    时间限制
    400 ms
    内存限制
    65536 kB

    给定一个单链表,请编写程序将链表元素进行分类排列,使得所有负值元素都排在非负值元素的前面,而[0, K]区间内的元素都排在大于K的元素前面。但每一类内部元素的顺序是不能改变的。例如:给定链表为 18→7→-4→0→5→-6→10→11→-2,K为10,则输出应该为 -4→-6→-2→7→0→5→10→18→11。

    输入格式:

    每个输入包含1个测试用例。每个测试用例第1行给出:第1个结点的地址;结点总个数,即正整数N (<= 105);以及正整数K (<=1000)。结点的地址是5位非负整数,NULL地址用-1表示。

    接下来有N行,每行格式为:

    Address Data Next

    其中Address是结点地址;Data是该结点保存的数据,为[-105, 105]区间内的整数;Next是下一结点的地址。题目保证给出的链表不为空。

    输出格式:

    对每个测试用例,按链表从头到尾的顺序输出重排后的结果链表,其上每个结点占一行,格式与输入相同。

    输入样例:
    00100 9 10
    23333 10 27777
    00000 0 99999
    00100 18 12309
    68237 -6 23333
    33218 -4 00000
    48652 -2 -1
    99999 5 68237
    27777 11 48652
    12309 7 33218
    
    输出样例:
    33218 -4 68237
    68237 -6 48652
    48652 -2 12309
    12309 7 00000
    00000 0 99999
    99999 5 23333
    23333 10 00100
    00100 18 27777
    27777 11 -1

    分析:
      由于地址为5位非负整数,可以用数组 m[100010] 存储该链表;
      输入后从首地址按链表顺序遍历,将节点分为三组存入v[0],v[1],v[2],依次输出。
     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 
     4 struct Node{
     5     int val,adr,next;
     6 }m[100010];
     7 int main()
     8 {
     9     vector<Node> v[3];
    10     int s,n,k;
    11     Node node;
    12     scanf("%d %d %d",&s,&n,&k);
    13     for(int i=0,t;i<n;i++){
    14         scanf("%d",&t);
    15         m[t].adr=t;
    16         scanf("%d %d",&m[t].val,&m[t].next);
    17     }
    18     while(s!=-1){
    19         if(m[s].val<0) v[0].push_back(m[s]);
    20         else if(m[s].val<=k) v[1].push_back(m[s]);
    21         else v[2].push_back(m[s]);
    22         s=m[s].next;
    23     }
    24     int notFirst=0;
    25     for(int i=0;i<3;i++){
    26         for(auto t:v[i]){
    27             if(!notFirst++) printf("%05d %d ",t.adr,t.val);
    28             else printf("%05d
    %05d %d ",t.adr,t.adr,t.val);
    29         }
    30     }
    31     puts("-1");
    32     return 0;
    33 }
     
  • 相关阅读:
    数学分析学习笔记
    参数注解检查方法入参
    AOP 织入 Redis 缓存
    手写单例 Redis 分布式锁
    Leetcode 347 前K个高频元素 topK问题手写大顶堆
    PCB 网页WebODB++与Genesis同屏实现方法
    Git多密钥配置
    npm安装问题解决
    设计模式
    odoo14里面开发一个简单的action.client 的tag 模板例子
  • 原文地址:https://www.cnblogs.com/Fresh--air/p/8568850.html
Copyright © 2011-2022 走看看