L2-022 重排链表

一、题目

二、解题思路

  1. 结构体数组的下标表示该节点的地址,value 表示该节点的值,nextkey 表示下一个结点的地址。
  2. 输入的节点不一定都属于这个链表:将此链表中的节点按顺序存储在数组中,并记录合法节点的个数 k ,数组中存放的是各节点的地址。
  3. 按照题目指定的顺序输出,注意考虑合法节点个数的奇偶性以及最后一个节点的下一个结点的地址为 -1 。

三、代码

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

struct List
{
	int value,nextkey;
}a[100005];

int main()
{
	int index,n,result[100005];
	cin>>index>>n;
	for(int i=0;i<n;i++)
	{
		int key;
		cin>>key;
		cin>>a[key].value>>a[key].nextkey;
	}
	int k=0;
	while(index!=-1)
	{
		result[k++]=index;
		index=a[index].nextkey;
	}
	int i=0,j=k-1,cot=0;
	for(;cot<(k+1)/2-1;i++,j--,cot++)
	{
		printf("%05d %d %05d\n",result[j],a[result[j]].value,result[i]);
		printf("%05d %d %05d\n",result[i],a[result[i]].value,result[j-1]);
	}
	if(k%2==0)
	{
		printf("%05d %d %05d\n",result[j],a[result[j]].value,result[i]);
	}
	printf("%05d %d -1\n",result[i],a[result[i]].value);
	return 0;
}

四、总结

输入的节点不一定都属于这个链表(测试点 3 )。

相关推荐
bestadc5 分钟前
LeetCode 几道 Promises 和 Time 的题目
javascript·算法·leetcode
墨染点香12 分钟前
LeetCode 刷题【71. 简化路径】
算法·leetcode·职场和发展
知彼解己14 分钟前
【算法】四大基础数据结构
数据结构·算法
老一岁16 分钟前
希尔排序详解
数据结构·算法·排序算法
lifallen17 分钟前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
索迪迈科技20 分钟前
java后端工程师进修ing(研一版‖day42)
java·开发语言·学习·算法
名誉寒冰38 分钟前
LeetCode 24 两两交换链表中的节点( 迭代与递归)
算法·leetcode·链表
小欣加油39 分钟前
leetcode LCR 170.交易逆序对的总数
数据结构·c++·算法·leetcode·职场和发展·排序算法
focksorCr41 分钟前
编译缓存工具 sccache 效果对比
c++·缓存·rust
kyle~1 小时前
排序---希尔排序(Shell Sort)
数据结构·算法·排序算法