《LeetCode 零基础指南》(第五讲)排序

HEU_firejef 2022-04-07 07:50:22

一、概念理解

排序就是将一堆无序的元素转变为有序的元素

二、熟悉语法

vector<int>res;

sort函数 sort(res.begin(),res.end());降序。

              sort (res,begin(),res.end(),greater<int>())升序。

三、实战演练

912. 排序数组

class Solution {

public:

    vector<intsortArray(vector<int>& nums) {

        sort(nums.begin(),nums.end());

        return nums;

    }

};

思路分析,用sort函数排序即可。

169. 多数元素

class Solution {

public:

    int majorityElement(vector<int>& nums) {

        sort(nums.begin(),nums.end());

        int length=nums.size();

        return nums[length/2];

    }

};

思路分析:直接排序然后输出下标为length/2的元素(因为这个位置必定是一个数量大于(n/2)下界的元素。当然也可以用哈希表来解决问题。

217. 存在重复元素

 

class Solution {

public:

    bool containsDuplicate(vector<int>& nums) {

        int length=nums.size();

        sort(nums.begin(),nums.end());

        for(int i=0;i<length-1;i++){

            if(nums[i]==nums[i+1]){

                return true;

            }

        }

    return false;

    }

};

思路分析:如果用双指针暴力的话,那么就是时间复杂度o{n^2)的算法,会超时,所以先排序,然后先行枚举找出两个相同的返回true,否则返回false。

164. 最大间距

class Solution {

public:

    int maximumGap(vector<int>& nums) {

        int length=nums.size();

        if(length<2){

            return 0;

        }

        sort(nums.begin(),nums.end());

        int max0=-100010;

        for(int i=0;i<length-1;i++){

            if(abs(nums[i]-nums[i+1])>max0){

                max0=abs(nums[i]-nums[i+1]);

            }

        }

    return max0;

    }

};

思路分析:先排序,然后用线性枚举的思路逐项比较差值找出最大的即可。

905. 按奇偶排序数组

 

class Solution {

public:

    vector<intsortArrayByParity(vector<int>& nums) {

        vector<int> res;

        for(int i=0;i<2;i++){

            for(int j=0;j<nums.size();j++){

                if(i==0&&nums[j]%2==0){

                    res.push_back(nums[j]);

                }

 

                if(i==1&&nums[j]%2!=0){

                    res.push_back(nums[j]);

                }

            }

        }

    return res;

    }

};

思路分析:直接两次遍历,第一次遍历出所有的偶数元素,第二次遍历出所有的奇数元素。

539. 最小时间差

class Solution {

public:

    int findMinDifference(vector<string>& timePoints) {

        int length=timePoints.size();

        vector<int>res;

        for(int i=0;i<length;i++){

            int x=(timePoints[i][0]*10+timePoints[i][1])*60;

            int y=(timePoints[i][3]*10+timePoints[i][4]);

            res.push_back(x+y);

        }

        int min0=1441;

        sort(res.begin(),res.end());

        for(int i=1;i<length;i++){

            if(min0>(res[i]-res[i-1])){

                min0=res[i]-res[i-1];

            }

        }

        min0=min(min0,1440-(res[length-1]-res[0]));

        return min0;

    }

};

 

思路分析:先用一个整数的容器将所有的容器化成分钟数,然后逐项相减和min0做比较。如果小于min0赋值。最后不能忘掉用1440-(最后的元素-首部的元素)。

976. 三角形的最大周长

class Solution {

public:

    int largestPerimeter(vector<int>& nums) {

        sort(nums.begin(),nums.end());

        int length=nums.size();

        for(int i=length-1;i>=2;i--){

            if(nums[i]<nums[i-1]+nums[i-2]){

                return (nums[i]+nums[i-1]+nums[i-2]);

            }

        }

    return 0;

    }

};

思路分析:先排序,然后从length-1开始枚举,如果出现满足两边之和大于第三边的情况就返回即可。

881. 救生艇

class Solution {

public:

    int numRescueBoats(vector<int>& peopleint limit) {

        int length=people.size();

        int ret=0;

        sort(people.begin(),people.end());

        int i=0;

        int j=length-1;

        while(i<j){

            if(people[i]+people[j]<=limit){

                i++;

                j--;

                ret++;

            }

            else{

                j--;

                ret++;

            }

        }

        if(i==j){

            ret++;

        }

    return ret;

    }

};

思路分析:先排序,然后双指针(一个从下标为0开始,一个从下标为length-1开始)如果两者相加小于限制,则一起上船,否则质量大的单独上船。最后判断(i==j)的情况让i单独上船即可。

四、复盘阶段:

熟悉了排序的语句,并且熟悉了用双指针来解决一些问题(比如最后一条就是一道双指针的问题,用双指针来进行枚举就行)

...全文
114 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,077

社区成员

发帖
与我相关
我的任务
社区描述
学习「 算法 」的捷径就是 「 题海战略 」,社区由「 夜深人静写算法 」作者创建,三年ACM经验,校集训队队长,亚洲区域赛金牌,世界总决赛选手。社区提供系统的训练,答疑解惑,面试经验,大厂内推等机会
社区管理员
  • 英雄哪里出来
  • 芝麻粒儿
  • Amy卜bo皮
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

QQ群:480072171

英雄算法交流 8 群

 

试试用AI创作助手写篇文章吧