关键词:链表,查找
试题链接:
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);
}
}
}