基础算法集训第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;
    }
};
相关推荐
wuhen_n5 分钟前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
努力学算法的蒟蒻6 分钟前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_8414956410 分钟前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
AC赳赳老秦12 分钟前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
独好紫罗兰32 分钟前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_8414956436 分钟前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
budingxiaomoli37 分钟前
优选算法-字符串
算法
我是咸鱼不闲呀1 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
qq7422349841 小时前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程
数智工坊1 小时前
【数据结构-树与二叉树】4.5 线索二叉树
数据结构