首页 > 其他 > 详细

Problem Reorder List

时间:2014-07-07 16:41:33      阅读:384      评论:0      收藏:0      [点我收藏+]

Problem Description:

Given a singly linked list LL0→L1→…→Ln-1→Ln,

reorder it to: L0→LnL1→Ln-1→L2→Ln-2→…

You must do this in-place without altering the nodes‘ values.

For example,
Given {1,2,3,4}, reorder it to {1,4,2,3}.

 

Solution: 
 1 public void reorderList(ListNode head) {
 2         int length = 0;
 3         ListNode p = head;
 4         List<ListNode> list = new ArrayList<ListNode>();
 5         while (p != null) {
 6             length++;
 7             list.add(p);
 8             p = p.next;
 9         }
10         int i = 0;
11         p = null;
12         while (i <= (length - 1 - i)) {
13             if (p != null) {
14                 p.next = list.get(i);
15             }
16             if (i != length -1 -i) {
17                 list.get(i).next = list.get(length - 1-i);
18                 p = list.get(length-1-i);
19                 p.next = null;
20             } else {
21                 list.get(i).next = null;
22             }
23 
24             i++;
25         }
26     }

 

Problem Reorder List,布布扣,bubuko.com

Problem Reorder List

原文:http://www.cnblogs.com/liew/p/3815020.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!