伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

2021-03-27:给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置

来源:本站原创 浏览:89次 时间:2022-04-21

2021-03-27:给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。输入:head = 1→2→3→4→5, k = 2,输出:4→5→1→2→3。

福大大 答案2020-03-27:

1.找尾节点并且计算链表节点个数。
2.如果k大于等链表节点个数,需要取模,k一定在[0,节点个数)范围之内。如果k=0,直接返回头节点。
3.求倒数k+1的节点。
4.缓存倒数第k节点ans。
5.尾节点连头节点。
6.倒数k+1节点的Next指针为空。
7.返回ans。

代码用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: 4}    printlnLinkNodeList(head)    k := 6    fmt.Println("k =", k)    fmt.Println("----------------")    ret := rotateRight(head, k)    printlnLinkNodeList(ret)}type ListNode struct {    Val  int    Next *ListNode}func rotateRight(head *ListNode, k int) *ListNode {    if head == nil {        return head    }    //找尾节点并且计数    cnt := 1    tail := head    for tail.Next != nil {        cnt++        tail = tail.Next    }    k = k % cnt    if k == 0 { //刚好是头节点,就不用操作了。        return head    }    //找倒数第k+1节点    fast := head    slow := head    k++    for k > 0 {        fast = fast.Next        k--    }    for fast != nil {        fast = fast.Next        slow = slow.Next    }    //缓存结果    ans := slow.Next    //尾节点连头节点    tail.Next = head    //倒数k+1节点无Next指针    slow.Next = nil    return ans}//链表打印func printlnLinkNodeList(head *ListNode) {    cur := head    for cur != nil {        fmt.Print(cur.Val, "\t")        cur = cur.Next    }    fmt.Println()}

执行结果如下:


力扣61. 旋转链表
评论

  推荐站点

  • 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