> 백엔드 개발 > Golang > 예는 golang이 연결 목록 반전을 구현하는 방법을 보여줍니다.

예는 golang이 연결 목록 반전을 구현하는 방법을 보여줍니다.

PHPz
풀어 주다: 2023-04-18 09:23:41
원래의
570명이 탐색했습니다.

연결된 목록 역전은 고전적인 알고리즘 문제이며 데이터 구조 및 알고리즘에서 매우 중요한 지식 포인트입니다. 연결리스트 반전은 실무와 면접에서 널리 사용될 수 있으므로 프로그래머가 연결리스트 반전 알고리즘을 익히는 것이 매우 필요합니다.

Go 언어에서 연결 목록 반전 알고리즘을 구현하는 것도 매우 간단합니다. 아래에서는 연결 목록 반전 알고리즘을 구현하는 방법을 보여 드리겠습니다.

  1. 연결리스트의 기초

먼저 연결리스트의 기본지식을 간략히 소개하겠습니다. 연결된 목록은 여러 노드로 구성된 비선형 데이터 구조입니다. 각 노드에는 두 가지 속성이 있습니다. 하나는 데이터 요소의 값을 저장하는 속성이고 다른 하나는 다음 노드에 대한 포인터입니다.

연결된 목록은 배열에 비해 많은 장점이 있습니다. 예를 들어 연결 목록에 저장된 요소 수를 미리 알지 못해도 요소를 동적으로 추가하거나 삭제할 수 있습니다.

간단한 연결 목록 노드는 다음과 같이 정의할 수 있습니다.

type ListNode struct {
    Val  int
    Next *ListNode
}
로그인 후 복사

이 정의에서 Val은 이 노드에 저장된 값이고 Next는 다음 노드에 대한 포인터입니다. 노드 . 이 노드가 연결 목록의 마지막 노드인 경우 Nextnil을 가리킵니다. Val 是这个节点存储的值,Next 是一个指向下一个节点的指针。如果这个节点是链表的最后一个,Next 就指向 nil

链表的头节点表示链表的开头,通常也称为“哨兵节点”或“虚拟节点”。它不存储任何值,只是指向第一个实际的节点。

  1. 链表反转算法

现在我们开始讲解链表反转算法的实现。链表反转算法的基本思路就是遍历整个链表,把每个节点的指针方向反转,最后把头节点指向原链表的尾节点,完成整个链表的反转。

链表反转算法的关键过程就是每个节点的指针反转,具体实现方式如下:

// 将链表反转
func reverseList(head *ListNode) *ListNode {
    var prev, cur *ListNode
    cur = head
    for cur != nil {
        cur.Next, prev, cur = prev, cur, cur.Next
    }
    return prev
}
로그인 후 복사

这个算法的核心就是定义了两个指针 prevcur,分别表示前一个节点和当前节点。从头节点开始遍历整个链表,每次循环交换 prevcur 指针的指向,同时让 cur

연결된 목록의 헤드 노드는 연결 목록의 시작을 나타내며, 종종 "센티넬 노드" 또는 "가상 노드"라고도 합니다. 어떤 값도 저장하지 않으며 단지 첫 번째 실제 노드를 가리킵니다.
    1. 연결된 목록 반전 알고리즘

    이제 연결 목록 반전 알고리즘의 구현에 대해 설명하기 시작합니다. 연결 리스트 역전 알고리즘의 기본 아이디어는 연결 리스트 전체를 순회하고, 각 노드의 포인터 방향을 역전시킨 후, 마지막으로 헤드 노드를 원래 연결 리스트의 테일 노드로 향하게 하여 역전을 완료하는 것이다. 전체 연결리스트.

    링크드 리스트 반전 알고리즘의 핵심 프로세스는 각 노드의 포인터를 반전시키는 것입니다. 구체적인 구현 방법은 다음과 같습니다.

    func main() {
        // 初始化一个链表
        n1 := &ListNode{Val: 1}
        n2 := &ListNode{Val: 2}
        n3 := &ListNode{Val: 3}
        n4 := &ListNode{Val: 4}
        n1.Next = n2
        n2.Next = n3
        n3.Next = n4
        // 打印原链表
        printList(n1)
        // 反转链表
        newHead := reverseList(n1)
        // 打印反转后的链表
        printList(newHead)
    }
    
    // 打印链表
    func printList(head *ListNode) {
        p := head
        for p != nil {
            fmt.Printf("%d -> ", p.Val)
            p = p.Next
        }
        fmt.Println("nil")
    }
    로그인 후 복사
      이 알고리즘의 핵심은 prev 두 개의 포인터를 정의하는 것입니다. 및 cur는 각각 이전 노드와 현재 노드를 나타냅니다. <code>cur가 다음 노드.
    Testing

    🎜마지막으로 일부 테스트 사례를 통해 코드가 올바른지 확인할 수 있습니다. 🎜
    1 -> 2 -> 3 -> 4 -> nil
    4 -> 3 -> 2 -> 1 -> nil
    로그인 후 복사
    🎜출력: 🎜rrreee🎜🎜Summary🎜🎜🎜연결된 목록 반전은 매우 고전적인 알고리즘 문제입니다. 이 문서에서는 Go 언어에서 연결 목록 반전 알고리즘을 구현하는 방법을 소개합니다. 이 알고리즘을 학습함으로써 우리는 연결 목록과 포인터에 대한 이해를 더욱 강화하고 심화시킵니다. 🎜

위 내용은 예는 golang이 연결 목록 반전을 구현하는 방법을 보여줍니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿