8288分类目录 8288分类目录 8288分类目录
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

2021-04-08:给定一个单链表的头节点head,请判断该链表是否为回文结构。

来源:本站原创 浏览:96次 时间:2022-01-31

2021-04-08:给定一个单链表的头节点head,请判断该链表是否为回文结构。

福大大 答案2021-04-08:

1.找中点。
2.按中点切分成两个链表。
3.反转右边链表。
4.相等判断。
5.反转右边链表。
6.左右链表合并。
7.返回true或者false。

代码用golang编写。代码如下:

package mainimport "fmt"func main() {    head := &ListNode{Val: 1}    head����,��̥.Next = &ListNode{Val: 2}    head.Next.Next = &ListNode{Val: 3}    head.Next.Next.Next = &ListNode{Val: 3}    head.Next.Next.Next.Next = &ListNode{Val: 2}    head.Next.Next.Next.Next.Next = &ListNode{Val: 1}    printlnLinkNodeList(head)    ret := isPalindrome(head)    printlnLinkNodeList(head)    fmt.Println(ret)}//Definition for singly-linked list.type ListNode struct {    Val  int    Next *ListNode}//链表打印func printlnLinkNodeList(head *ListNode) {    cur := head    for cur != nil {        fmt.Print(cur.Val, "\t")        cur = cur.Next    }    fmt.Println()}//获取中点func GetMid(head *ListNode) *ListNode {    fast := head    slow := head    if fast.Next != nil && fast.Next.Next != nil {        fast = fast.Next.Next        slow = slow.Next    }    return slow}//反转链表func Reverse(head *ListNode) *ListNode {    var pre *ListNode    cur := head    var next *ListNode    for cur != nil {        next = cur.Next        cur.Next = pre        //准备下一次循环        pre, cur = cur, next    }    return pre}func isPalindrome(head *ListNode) bool {    if head == nil || head.Next == nil {        return true    }    //找中点    mid := GetMid(head)    //切断成两个链表    rStart := mid.Next    mid.Next = nil    //反转右边链表    rEnd := Reverse(rStart)    //相等判断    n1 := head    n2 := rEnd    ans := true    for n1 != nil && n2 != nil {        if n1.Val != n2.Val {            ans = false            break        }        n1, n2 = n1.Next, n2.Next    }    //反转右边链表    Reverse(rEnd)    //左右链表合并    mid.Next = rStart    return ans}

执行结果如下:


左神java代码
评论

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net