zoukankan      html  css  js  c++  java
  • leecode第六十一题(旋转链表)

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode(int x) : val(x), next(NULL) {}
     * };
     */
    class Solution {
    public:
        ListNode* rotateRight(ListNode* head, int k) {
            if(head==NULL)//特殊情况-空
                return NULL;
            if(head->next==NULL)//特殊情况-只有一个节点
                return head;
            
            ListNode* node=head;
            int len=1;
            while(node->next!=NULL)//获得长度
            {
                node=node->next;
                len++;
            }
            
            node=head;
            int n=len-k%len;
            for(int i=0;i<(n-1);i++)//计算并得到新的头节点之前的那个节点
                node=node->next;
            
            if(node->next==NULL)//若这个节点是原尾节点,直接返回原数组
                return head;
            ListNode* new_head=node->next;//若不是,干三件事,第一得到新的头结点
            node->next=NULL;//第二把新头结点前的节点的next赋NULL
            node=new_head;
            while(node->next!=NULL)//第三把原尾节点的next由NULL改为原头结点
                node=node->next;
            node->next=head;
            
            return new_head;
        }
    };

    分析:

    这个算法时间复杂度,因为只是遍历两遍链表,理论上是O(n),为了得到链表长度多遍历一遍,想了半天也没有其他的路子,后来想想相比一点点挪应该是快的吧。

    写的时候有两个关键地方第一时间都没想到,第一是新节点的计算,由于举得案例不全,也巧合,导致我一开始写的不对。第二是没注意到新的节点就是头结点的情况,因为我这个算法最后面还有while循环,所以没有考虑到这个情况的时候,这个是死循环。

    今天真的不能再做了,太累了。

  • 相关阅读:
    apollo使用场景2
    我问问
    洛谷 P3979 遥远的国度
    小技巧—对拍和输出文件的比较
    洛谷 P6850 NOI
    小技巧—双向边快速枚举
    ZJOI 2008 骑士
    小技巧—指数形式的枚举
    小技巧—滚动数组
    刷题心得—背包问题的枚举方式
  • 原文地址:https://www.cnblogs.com/CJT-blog/p/10597277.html
Copyright © 2011-2022 走看看