栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

重排链表(Java)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

重排链表(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 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/657967.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号