leetcode 25. k 개 반전 링크
하나의 체인 시 계 를 제시 하고 k 개의 노드 마다 한 조 를 뒤 집 으 며 뒤 집 힌 링크 를 되 돌려 줍 니 다.
k 는 정수 로 링크 의 길이 보다 작 거나 같 습 니 다.만약 에 노드 총수 가 k 의 정수 배가 아니라면 마지막 남 은 노드 를 원래 의 순서 로 유지 합 니 다.
예시:
:1->2->3->4->5
k = 2 , : 2->1->4->3->5
k = 3 , : 3->2->1->4->5
설명:
문제 풀이 의 사고 방향.
1. K , K , , K , ,return
2. K , ,
코드 구현
// ListNode Definition for singly-linked list.
type ListNode struct {
Val int
Next *ListNode
}
func reverseKGroup(head *ListNode, k int) *ListNode {
if k < 2 || head == nil || head.Next == nil {
return head
}
tail, needReverse := getTail(head, k)
if needReverse {
tailNext := tail.Next
// tail
tail.Next = nil
head, tail = reverse(head, tail)
//tail
tail.Next = reverseKGroup(tailNext, k)
}
return head
}
func getTail(head *ListNode, k int) (*ListNode, bool) {
for k > 1 && head != nil {
head = head.Next
k--
}
return head, k == 1 && head != nil
}
func reverse(head, tail *ListNode) (*ListNode, *ListNode) {
//
prev, cur := head, head.Next
for cur != nil {
prev, cur, cur.Next = cur, cur.Next, prev
}
return tail, head
}
GitHub
leetcode 25. k 개 반전 링크
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.