基础算法集训第06天:计数排序

目录

[75. 颜色分类 - 力扣(LeetCode)](#75. 颜色分类 - 力扣(LeetCode))

[1046. 最后一块石头的重量 - 力扣(LeetCode)](#1046. 最后一块石头的重量 - 力扣(LeetCode))

[1984. 学生分数的最小差值 - 力扣(LeetCode)](#1984. 学生分数的最小差值 - 力扣(LeetCode))

[389. 找不同 - 力扣(LeetCode)](#389. 找不同 - 力扣(LeetCode))

[2733. 既不是最小值也不是最大值 - 力扣(LeetCode)](#2733. 既不是最小值也不是最大值 - 力扣(LeetCode))


75. 颜色分类 - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {
        int p0=0;
        int p1=0;
        for(int i=0;i<nums.size();i++){
            if(nums[i]==1){
                swap(nums[i],nums[p1++]);
            }
            else if(nums[i]==0){
                swap(nums[i],nums[p0]);
                if(p0<p1){
                    swap(nums[i],nums[p1]);
                }
                p1++;
                p0++;
            }
        }
    }
};

1046. 最后一块石头的重量 - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    int lastStoneWeight(vector<int>& stones) {
        priority_queue<int> p;
        for(int i=0;i<stones.size();i++){
            p.push(stones[i]);
        }
        while(p.size()>1){
            int a=p.top();
            p.pop();
            int b=p.top();
            p.pop();
            if(a!=b){
                p.push(a-b);
            }
        }
        if(p.size()==0){
            return 0;
        }
        else {
            return p.top();
        }
    }
};

1984. 学生分数的最小差值 - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    int minimumDifference(vector<int>& nums, int k) {
        sort(nums.begin(), nums.end());
        int MIN = INT_MAX;
        for (int i = 0; i < nums.size() - k + 1; i++) {
            MIN = min(MIN, nums[k + i - 1] - nums[i]);
        }
        return MIN;
    }
};

389. 找不同 - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    char findTheDifference(string s, string t) {
        int res=0;
        for(int i=0;i<s.size();i++){
            int k=s[i]-'a';
            res^=k;
        }
        for(int i=0;i<t.size();i++){
            int k=t[i]-'a';
            res^=k;
        }
        char n=res+'a';
        return n;
    }
};

2733. 既不是最小值也不是最大值 - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    int findNonMinOrMax(vector<int>& nums) {
        if(nums.size()<=2)return -1;
        int MIN=nums[0];
        int MAX=nums[0];
        for(int i=0;i<nums.size();i++){
            MIN=min(MIN,nums[i]);
            MAX=max(MAX,nums[i]);
        }
        for(int i=0;i<nums.size();i++){
            if(nums[i]!=MIN&&nums[i]!=MAX){
                return nums[i];
            }
        }
        return -1;
    }
};
相关推荐
cici158742 分钟前
图像匹配算法:灰度相关法、相位相关法与金字塔+相位相关法
算法
佚名ano3 分钟前
支持向量机SVM的简单推导过程
算法·机器学习·支持向量机
云泽8085 分钟前
蓝桥杯算法精讲:倍增思想与离散化深度剖析
算法·职场和发展·蓝桥杯
m0_569881476 分钟前
基于C++的数据库连接池
开发语言·c++·算法
.select.13 分钟前
c++ auto
开发语言·c++·算法
2401_8845632416 分钟前
C++中的访问者模式高级应用
开发语言·c++·算法
智者知已应修善业21 分钟前
【51单片机用两个定时计数器级联实现定时】2023-04-12
c语言·经验分享·笔记·算法·51单片机
君义_noip22 分钟前
信息学奥赛一本通 1613:打印文章
c++·算法·信息学奥赛·csp-s
nglff30 分钟前
蓝桥杯抱佛脚第四天|前缀和,差分对应练习
算法·职场和发展·蓝桥杯
freexyn1 小时前
Matlab入门自学七十四:坐标系转换,直角坐标、极坐标和球坐标的转换
开发语言·算法·matlab