[编程题]Linked List Sorting

关键词:链表,查找
试题链接:
Linked List Sorting
问题描述:
在这里插入图片描述
在这里插入图片描述

思路:
由于题目提到的地址范围很小,所以可以考虑用静态链表来解决问题。依照题目的要求,需要在node结构体中新添一个flag的变量用于记录当前结点是否在结点链中(是否为有效结点),读取输入完毕以后,用sort函数进行排序,先按照有效结点排前面的规则排序,再按照结点中数据从小到大的顺序进行排序。

备注:
这道题需要注意的是在它给出的一大串输入里面,可能有的结点根本就不再链表里面,这个时候按照地址需要遍历一遍静态链表,把在链表里的结点全部标记为有效结点,方便后面的排序。
在这里插入图片描述

题目比较简单,需要注意的还是它的输出格式。
解决方案:

#include<iostream>
#include <iomanip>
#include<algorithm>

using namespace std;
const int maxn=100010;

struct NODE{
    int ad=-1;
    int next=-1;
    int num;
    int flag=-1; //记录当前结点是否有效
} nodes[maxn];

bool cmp(NODE n1,NODE n2){
    if(n1.flag!=n2.flag){ //有效结点排在无效结点的前面
        return n1.flag>n2.flag;
    }else if(n1.flag==1){
        return n1.num<n2.num; //当n1 num小于n2 num时把n1放在前面
    }
}

//输入的结点可能根本不在列表里面
int main(){
    int ad,n;
    cin>>n>>ad;
    while(n--){
        int a1,a2;
        int num;
        cin>>a1>>num>>a2;
        nodes[a1].ad=a1;
        nodes[a1].num=num;
        nodes[a1].next=a2;
    }
    int p; //遍历列表标记结点是否有效
    int cnt=0; //列表里面的有效结点数
    for(p=ad;p!=-1;p=nodes[p].next){
        nodes[p].flag=1;//当前结点变得有效
        cnt++;
    }
    sort(nodes,nodes+maxn,cmp); //排序
    if(nodes[0].ad!=-1){
        printf("%d %05d\n",cnt,nodes[0].ad);
    }else{
        printf("%d %d\n",cnt,nodes[0].ad);
    }

    for(int i=0;i<cnt;i++){
        if(i!=cnt-1){
            nodes[i].next=nodes[i+1].ad;
        }else{
            nodes[i].next=-1;
        }
        if(nodes[i].next!=-1){
            printf("%05d %d %05d\n",nodes[i].ad,nodes[i].num,nodes[i].next);
        }else{
            printf("%05d %d %d\n",nodes[i].ad,nodes[i].num,nodes[i].next);
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值