#yyds干货盘点# 面试必刷TOP101:链表的奇偶重排

网友投稿 506 2022-10-23

#yyds干货盘点# 面试必刷TOP101:链表的奇偶重排

#yyds干货盘点# 面试必刷TOP101:链表的奇偶重排

简述:

描述

给定一个单链表,请设定一个函数,将链表的奇数位节点和偶数位节点分别放在一起,重排后输出。

注意是节点的编号而非节点的数值。

示例1

输入:

{1,2,3,4,5,6}

返回值:

{1,3,5,2,4,6}

说明:

1->2->3->4->5->6->NULL重排后为1->3->5->2->4->6->NULL

示例2

输入:

{1,4,6,3,7}

返回值:

{1,6,7,4,3}

说明:

1->4->6->3->7->NULL重排后为1->6->7->4->3->NULL奇数位节点有1,6,7,偶数位节点有4,3。重排后为1,6,7,4,3

代码实现:

import java.util.*;public class Solution { public ListNode oddEvenList (ListNode head) { //如果链表为空,不用重排 if(head == null) return head; //even开头指向第二个节点,可能为空 ListNode even = head.next; //odd开头指向第一个节点 ListNode odd = head; //指向even开头 ListNode evenhead = even; while(even != null && even.next != null){ //odd连接even的后一个,即奇数位 odd.next = even.next; //odd进入后一个奇数位 odd = odd.next; //even连接后一个奇数的后一位,即偶数位 even.next = odd.next; //even进入后一个偶数位 even = even.next; } //even整体接在odd后面 odd.next = evenhead; return head; }}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Mars - Vue 驱动的多端开发框架
下一篇:Python异步引擎Twisted实现Zinx框架
相关文章

 发表评论

暂时没有评论,来抢沙发吧~