当前位置: 首页 > news >正文

leetcode 169.Majority Element

这道题虽然简单,但适合用来练习各种解法。

用哈希表解决

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        unordered_map<int,int> count;
        int majority = 0;
        int cnt = 0;
        for(auto num:nums){
            count[num]++;
            if(count[num] > cnt){
                cnt = count[num];
                majority = num;
            }
        }
        return majority;
    }
};

先排序再取nums[n/2]

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int len = nums.size();
        srand(time(0));
        quick_sort(nums,0,len-1);
        return nums[len/2];
    }

    int partition(vector<int>& nums,int left,int right){
        if(left >= right)
            return left;
        int random = rand()%(right - left +1);
        swap(nums[left],nums[left + random]);
        int pivot = nums[left];
        while(left < right){
            while(left<right && pivot < nums[right]) right--;
            nums[left] = nums[right];  
            while(left<right && nums[left]<=pivot) left++;
            nums[right] = nums[left];
        }
        nums[left] = pivot;
        return left;
    }
    void quick_sort(vector<int>& nums,int left,int right){
        if(left>=right) return;
        int pivot_pos = partition(nums,left,right);
        quick_sort(nums,left,pivot_pos-1);
        quick_sort(nums,pivot_pos+1,right);
    }
};

随机化方法

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        srand(0);
        int len = nums.size();
        int random = 0; 
        int cnt = 0;
        while(true){
            random = rand()%len;
            cnt = 0;
            for(auto num:nums){
                if(num == nums[random]){
                    cnt++;
                    if(cnt >len/2)
                        return num;
                }
            }
        }
    }
};

相关文章:

  • window离线全局安装yarn
  • 【Rtklib入门指南】4. 使用RTKLIB进行载波相位差分定位(RTK)
  • Scala(2)
  • QT学习day1
  • 计算机视觉——传统数字图像处理中图像去噪原理与代码实现细节
  • 全长约8.3公里!宁波象山港跨海大桥南中塔柱云端合龙
  • 十五届蓝桥杯省赛Java B组(持续更新..)
  • 蓝桥杯专项复习——二分
  • 《Fundamentals of Electromigration-Aware IntegratedCircuit Design》笔记
  • HTML中数字和字母不换行显示
  • 【C++游戏引擎开发】《线性代数》(5):四元数的3D旋转原理与实现(含新增Vector3、修改Matrix为非SIMD版本)
  • 【区块链安全 | 第十九篇】类型之映射类型
  • 【Node.js入门笔记12---npm包】
  • 聊聊Spring AI的RetrievalAugmentationAdvisor
  • Unity TextMeshPro 实现文本逐字淡出效果
  • 5.02 WPF的 Combox、ListBox,slider、ProgressBar使用
  • C语言--插入排序
  • Kafka+Zookeeper从docker部署到spring boot使用完整教程
  • Vue:生命周期
  • 2025年山东水利水电 C 证考试精选题库
  • 动态网站开发与设计关键技术/东莞百度seo电话
  • wordpress统计分类数量/邯郸seo排名
  • 苏州网站建设哪家做得好/游戏推广员骗局
  • 资源网站模板/自己怎么做关键词优化
  • 网站建设违约/seo自动发布外链工具
  • 直播类网站开发/百度网站排名查询工具