leetcode 1365. 有多少小于当前数字的数字

2023.9.2

本题直观的解法就是双层for循环暴力求解:

暴力解:

cpp 复制代码
class Solution {
public:
    vector<int> smallerNumbersThanCurrent(vector<int>& nums) {
        vector<int> ans;
        for(int i=0; i<nums.size(); i++)
        {
            int temp = 0;//比当前元素小的元素个数
            for(int j=0; j<nums.size(); j++)
            {
                if(nums[j] < nums[i]) temp++;
            }
            ans.push_back(temp);
        }
        return ans;
    }
};

上述解法中,元素之间进行了重复比较,可以进行优化:

暴力解(优化版):

cpp 复制代码
class Solution {
public:
    vector<int> smallerNumbersThanCurrent(vector<int>& nums) {
        vector<int> ans(nums.size());
        for(int i=0; i<nums.size(); i++)
        {
            for(int j=i+1; j<nums.size(); j++)
            {
                if(nums[j] < nums[i]) ans[i]++;
                else if(nums[j] > nums[i]) ans[j]++;
            }
        }
        return ans;
    }
};

由于题中nums[i]给的范围是0~100,因此还可以以空间换时间,进一步优化:

哈希法:

cpp 复制代码
class Solution {
public:
    vector<int> smallerNumbersThanCurrent(vector<int>& nums) {
        vector<int> v(nums.begin(),nums.end());
        sort(v.begin(),v.end()); //排序之后,元素下标就是小于当前元素的个数
        int hash[101];

        for(int i=0; i<v.size(); i++)
        {
            if(i>0 && v[i]==v[i-1]) continue;
            hash[v[i]] = i;
        }

        for(int i=0; i<nums.size(); i++)
        {
            nums[i] = hash[nums[i]];
        }
        return nums;
    }
};
相关推荐
学习中的码虫15 小时前
(C++)从this构造shared_ptr导致多控制块的处理
c++
m0_7488394915 小时前
利用C 图形界面展示MATLAB算法的高效混合编程实践
开发语言·算法·matlab
进击的荆棘15 小时前
优选算法——哈希表
c++·算法·leetcode·哈希算法·散列表
阿牛大牛中15 小时前
阿里-RecGPT-Mobile
大数据·人工智能·算法
RH23121115 小时前
2026.5.17数据结构 八大排序
数据结构·算法·排序算法
毋语天15 小时前
NumPy 完全入门指南:核心数据结构与高效数值计算
数据结构·numpy
加号315 小时前
【C#】 实现 CRC16 校验:原理、算法与工程实践
算法·c#
蜡笔小马15 小时前
12.C++设计模式-模板方法模式
c++·设计模式·模板方法模式
江屿风15 小时前
【C++笔记】内存管理流食般投喂
开发语言·c++·笔记
雪度娃娃15 小时前
行为型设计模式——备忘录模式
服务器·c++·设计模式·备忘录模式