• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

cynchanpin

  • 博客园
  • 联系
  • 订阅
  • 管理

View Post

Reverse Nodes in k-Group

题目

Given a linked list, reverse the nodes of a linked list k at a time and return its modified list.

If the number of nodes is not a multiple of k then left-out nodes in the end should remain as it is.

You may not alter the values in the nodes, only nodes itself may be changed.

Only constant memory is allowed.

For example,
Given this linked list: 1->2->3->4->5

For k = 2, you should return: 2->1->4->3->5

For k = 3, you should return: 3->2->1->4->5

方法

首先推断是否须要反转元素。
假设须要。採用头插法又一次插入元素。
	    public ListNode reverseKGroup(ListNode head, int k) {
	        if(head == null || head.next == null || k == 1){
	            return head;
	        }
	        ListNode first = new ListNode(0);
	        first.next = head;
	        ListNode start = first;
	        ListNode end = first;
	        ListNode temp = head;
	        int i = 0;
	        int flag = 0 ;
	        while(flag == 0){
	            
	            if(i == 0){
	                ListNode list = temp;
	                int j = 1;
	                while(list != null && j < k){
	                    list = list.next;
	                    j ++;
	                }
	                if(j == k && list != null){
	                    end = temp;
	                    temp = temp.next;
	                    i ++;
	                }else{
	                    flag = 1;
	                }

	            }else{
	                end.next = temp.next;
	                temp.next = start.next;
	                start.next = temp;
	                if(i == k -1){
	                    i = 0;
	                    start = end;
	                }else{
	                    i ++;
	                }
	                temp = end.next;
	            }
	        }
	        return first.next;
	    }


posted on 2017-06-20 13:42  cynchanpin  阅读(252)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3