基础算法集训第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;
    }
};
相关推荐
Wect29 分钟前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP12 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱21 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试