重排链表(Java)

重排链表(Java),第1张

重排链表(Java)

给定一个单链表 L 的头节点 head ,单链表 L 表示为:
L0 → L1 → … → Ln - 1 → Ln

请将其重新排列后变为:
L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → ...

不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

示例 1:

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

示例 2:

 

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

 

package com.loo;

import java.util.ArrayList;
import java.util.List;

public class ReorderList {
	
	static class ListNode {
		int value;
		ListNode next;
		public ListNode(int v) {
			this.value = v;
		}
	}
	
	public static void listNode(ListNode head , int[] arr) {
		if (arr == null || arr.length == 0) {
			return;
		}
		ListNode node = head;
		for (int i=0;i list = new ArrayList();
		ListNode node = head;
		while (node!=null) {
			list.add(node);
			node = node.next;
		}
		int i = 0;
		int j = list.size() - 1;
		while (i 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5660039.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存