leetcode328-Odd Even Linked List

题目

给定单链表的头节点 head ,将所有索引为奇数的节点和索引为偶数的节点分别组合在一起,然后返回重新排序的列表。

第一个节点的索引被认为是 奇数 , 第二个节点的索引为 偶数 ,以此类推。

请注意,偶数组和奇数组内部的相对顺序应该与输入时保持一致。

你必须在 O(1) 的额外空间复杂度和 O(n) 的时间复杂度下解决这个问题。

示例 1:

输入: head = [1,2,3,4,5]

输出: [1,3,5,2,4]

分析

我们可以用俩个指针永远指向最新的奇数和偶数,不断把偶数后面的奇数插入到奇数后面,然后更新分别指向奇数和偶数的指针

java 复制代码
public class LinkNode {
	int val;
	LinkNode next;

	public LinkNode(int data) {
		this.val = data;
		this.next = null;
	}
}
public class LinkList {
	LinkNode head;
	public LinkList() {
		this.head = null;
	}
	public LinkNode getHead() {
		return this.head;
	}
	//添加元素
	public void addNode(int data) {
		LinkNode node = new LinkNode(data);
		if (this.head == null) {
			this.head = node;
		} else {
			LinkNode cur = this.head;
			while(cur.next != null) {
				cur = cur.next;
			}
			cur.next = node;
		}
	}
	//正序打印
	public void print(LinkNode node) {
		while(node != null) {
			System.out.print(node.val);
			System.out.print(" ");
			node = node.next;
		}
		System.out.println();
	}
	public void oddEvenList() {
		LinkNode p =this.head;
		if(p == null) {
			return;
		}
		LinkNode pre = this.head;
		LinkNode cur = this.head.next;
		while(cur != null && cur.next != null) {
			LinkNode next = cur.next;
			cur.next = next.next;
			next.next = pre.next;
			pre.next = next;
			pre = pre.next;
			cur = cur.next;
		}
		print(this.head);
	}
}

public class oddEvenLinkedList {
	public static void main(String[] args) {
		LinkList list = new LinkList();
		list.addNode(2);
		list.addNode(1);
		list.addNode(3);
		list.addNode(5);
		list.addNode(6);
		list.addNode(4);
		list.addNode(7);
		list.oddEvenList();
	}
}
相关推荐
MY_TEUCK1 小时前
Sealos 平台部署实战指南:结合 Cursor 与版本发布流程
java·人工智能·学习·aigc
我爱cope2 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
朝新_2 小时前
【Spring AI 】图像与语音模型实战
java·人工智能·spring
RH2312113 小时前
2026.4.16Linux 管道
java·linux·服务器
测试19983 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
zmsofts3 小时前
java面试必问13:MyBatis 一级缓存、二级缓存:从原理到脏数据,一篇讲透
java·面试·mybatis
故事和你913 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
我叫黑大帅3 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
M ? A4 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
aq55356005 小时前
编程语言三巨头:汇编、C++与PHP大比拼
java·开发语言