zoukankan      html  css  js  c++  java
  • leetcode刷题收获

    引言

       到目前为止,在leetcode上刷了近二十题,如果就这么刷下去,以下好处自然会有:coding熟练度的提升、STL的使用、思考和解决问题的熟练度。
       然而,数据结构和算法的进一步学习、未接触过的新的c++语言特性的学习、改掉编程中的陋习等等很难在刷题中达成,因此,需要有目标的刷题。

    刷题过程

    1. 追求效率,如果时间复杂度足够优化,排名前10%应该是没问题的
    2. 时间复杂度优化不出来的题,评论区看大佬的解答,然后想明白,最好自己再实现一遍
    3. 尝试使用未实践过的数据结构、算法、C++语言特性。
    4. 发现自己coding中的陋习,或是可改进的地方,对自己coding 能力的提升大有裨益

    技巧收获汇总

    1. 边界情况要主动处理好,比在调试的时候去纠正省时的多

    for example: 19. Remove Nth Node From End of List
    Given a linked list, remove the n-th node from the end of list and return its head.

    //Solution in one pass
    class Solution {
    public:
        ListNode* removeNthFromEnd(ListNode* head, int n) {
            //if(head->next==NULL) return NULL;
            vector<ListNode*> vl;
            ListNode *p=head;
            while(p!=NULL)
            {
                vl.push_back(p);
                p=p->next;
            }
            int i=vl.size()-n;
            if(i==0) return head->next;
            else if(i==vl.size()-1) vl[i-1]->next=NULL;
            else vl[i-1]->next=vl[i+1];
            return head;
        }
    };
    

      题中要求删除的位置的边界情况是,首元素 head 和 末尾元素,head 的特征是没有前驱元素, 末尾元素的特征是没有后继元素;这两种情况的处理和中间元素是不一样的。

    2. 使用STL提供的容器有时会影响效率

    for example: 20. Valid Parentheses
    我首先用map做了一遍,耗时12ms

    class Solution {
    public:
        bool isValid(string s) {
            stack<char> st;
            map<char,char> zuo;
            zuo[')']='(';
            zuo[']']='[';
            zuo['}']='{';
            int i;
            for(i=0;i<s.length();i++)
            {
                if(s[i]=='(' || s[i]=='{' || s[i]=='[') st.push(s[i]);
                else if(!st.empty() && st.top()==zuo[s[i]]) st.pop();
                else break;
            }
            if(st.empty() && i==s.length()) return true;
            else return false;
        }
    };
    

      然后用数组做了一遍,耗时4ms

    class Solution {
    public:
        bool isValid(string s) {
            stack<char> st;
            char zuo[300];
            zuo[')']='(';
            zuo[']']='[';
            zuo['}']='{';
            int i;
            for(i=0;i<s.length();i++)
            {
                if(s[i]=='(' || s[i]=='{' || s[i]=='[') st.push(s[i]);
                else if(!st.empty() && st.top()==zuo[s[i]]) st.pop();
                else break;
            }
            if(st.empty() && i==s.length()) return true;
            else return false;
        }
    };
    
  • 相关阅读:
    别以为真懂Openstack: 虚拟机创建的50个步骤和100个知识点(5)
    Docker容器(三)——容器端口映射以及访问后台运行的容器实例
    Docker容器(二)——镜像制作
    Docker容器(一)——Docker的介绍与部署
    Linux的桌面虚拟化技术KVM(五)——virsh常用命令
    Linux的桌面虚拟化技术KVM(四)——虚拟机镜像格式对比与转换
    Linux的桌面虚拟化技术KVM(三)——KVM虚拟机克隆和快照
    Linux的桌面虚拟化技术KVM(一)——新建KVM虚拟机
    Linux的桌面虚拟化技术KVM(二)——远程桌面管理
    搭建jumpserver堡垒机
  • 原文地址:https://www.cnblogs.com/yhjd/p/10654786.html
Copyright © 2011-2022 走看看