力扣 169. 多数元素

思路:

因为题目说一定存在多数元素,就说明一定有一个数的个数多于n/2

将数组采用冒泡从小到大排序,最中间的那个元素一定是多数元素 (因为在大小排好序后,中位数也一定是众数

答案:

复制代码
int majorityElement(int* nums, int numsSize) 
{
    int i=0,j=0;
    for(i=0;i<numsSize-1;i++)        //冒泡排序
    {
        int flag=1;
        for(j=1;j<numsSize-i;j++)
        {
            if(nums[j-1]>nums[j])
            {
                int tmp=nums[j];
                nums[j]=nums[j-1];
                nums[j-1]=tmp;
                flag=0;
            }
        }            
        if(flag)
        {
            break;
        }
    }
    return nums[numsSize/2];     //返回中位数
}
相关推荐
铭哥的编程日记3 分钟前
小企鹅装石头(栈模拟题)
算法
汉堡go5 分钟前
SLAM数学基础1
人工智能·算法·机器学习
qzhqbb5 分钟前
不可检测水印
人工智能·算法
快敲啊死鬼7 分钟前
机试day5
算法·华为od·华为
8Qi88 分钟前
LeetCode热题100--189
c语言·数据结构·c++·算法·leetcode
灰色小旋风8 分钟前
力扣第八题C++ 字符串转换整数
c++·算法·leetcode
@––––––11 分钟前
力扣hot100—系列9—图论
算法·leetcode·图论
pp起床12 分钟前
图论 | part01
算法·深度优先·图论
luckycoding13 分钟前
3676. 碗子数组的数目
算法·游戏·深度优先
灰色小旋风13 分钟前
力扣第十题C++正则表达式匹配
c++·leetcode·正则表达式