Reverse Nodes in k-Group [逆转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 class Solution {
	public ListNode reverseKGroup(ListNode head, int k) {
		if(head==null){
			return null;
		}
		int len=1;
		int i=0;
		int group=0;
		int r=0;
		ListNode p=head;
		//获取链表长度
		while(p.next!=null){
			len++;
			p=p.next;
		}
		if(head.next==null || k>len){
			return head;
		}

		//计算整组总数
		group=len/k;
		r=len%k;

		//倒序节点
//		ListNode fNode=null,pNode=head,next;
//		while(pNode!=null){
//			next=pNode.next;
//			pNode.next=fNode;
//			fNode=pNode;//当前节点下一轮就是别人的next了
//			pNode=next;
//		}
//		head=fNode;
		ListNode pNode=head,rNode=null,nNode=null;
		//用于记录当前位置
		int index=0;
		for(i=0;i<group;i++){
			index=i*k;
			if(index==len-r-1){
				break;
			}
//			int startIndex=i*k;
			if(i==0){
				rNode=Solution.reversePart_(pNode, k);
			}else{
				nNode=pNode.next;
				Solution.reversePart(pNode, k);
				pNode=nNode;
			}
		}
		return rNode;
	}

	//获取指定位置的节点
	public static ListNode getListNodeForIndex(ListNode n,int l){
		while(n!=null && l>0){
			n=n.next;
			l--;
		}
		return n;
	}
	//逆转从n.next到指定长度l
	public static ListNode reversePart(ListNode pNode,int l){
		ListNode next=null,fNode=null,fistNode=null,n=pNode.next;
		fistNode=n;
		while(n!=null && l>0){
			next=n.next;
			n.next=fNode;
			fNode=n;
			n=next;
			l--;
		}
		if(n!=null){
			fistNode.next=n;
		}
		pNode.next=fNode;
		return fNode;
	}
	//逆转从n到指定长度l
		public static ListNode reversePart_(ListNode n,int l){
			ListNode next=null,fNode=null,fistNode=null;
			fistNode=n;
			while(n!=null && l>0){
				next=n.next;
				n.next=fNode;
				fNode=n;
				n=next;
				l--;
			}
			if(n!=null){
				fistNode.next=n;
			}
			return fNode;
		} 

}
时间: 2024-10-27 02:06:33

Reverse Nodes in k-Group [逆转K-Group链表]的相关文章

[LintCode] Reverse Nodes in k-Group 每k个一组翻转链表

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 nod

LeetCode 25 Reverse Nodes in k-Group K个一组反转节点

题目: 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

leetCode 25.Reverse Nodes in k-Group (以k个节点为一组反转链表) 解题思路和方法

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 valu

[LeetCode] Reverse Nodes in k-Group 每k个一组翻转链表

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 nod

(Java) LeetCode 25. Reverse Nodes in k-Group —— k个一组翻转链表

Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k is a positive integer and is less than or equal to the length of the linked list. If the number of nodes is not a multiple of k then left-out nodes in

[LeetCode] 25. Reverse Nodes in k-Group 每k个一组翻转链表

Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k is a positive integer and is less than or equal to the length of the linked list. If the number of nodes is not a multiple of k then left-out nodes in

[LeetCode]25. Reverse Nodes in k-Group k个一组翻转链表

Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k is a positive integer and is less than or equal to the length of the linked list. If the number of nodes is not a multiple of k then left-out nodes in

K组翻转链表 &#183; Reverse Nodes in

[抄题]: 给你一个链表以及一个k,将这个链表从头指针开始每k个翻转一下.链表元素个数不是k的倍数,最后剩余的不用翻转. [思维问题]: [一句话思路]: // reverse head->n1->..->nk->next.. // to head->nk->..->n1->next.. // return n1 每k个转一次,再递归 [输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入): [画图]: [一刷]: [

LeetCode Reverse Nodes in k-Group 每k个节点为一组,反置链表

题意:给一个单链表,每k个节点就将这k个节点反置,若节点数不是k的倍数,则后面不够k个的这一小段链表不必反置. 思路:递归法.每次递归就将k个节点反置,将k个之后的链表头递归下去解决.利用原来的函数接口即可,不用重新定义. 1 /** 2 * Definition for singly-linked list. 3 * struct ListNode { 4 * int val; 5 * ListNode *next; 6 * ListNode(int x) : val(x), next(NUL