【分治法】众数问题

简介: 【分治法】众数问题

  题目描述:

1.    众数问题

问题描述:

  给定含有n 个元素的多重集合S,每个元素在S 中出现的次数称为该元素的重数。多重集S 中重数最大的元素称为众数。

例如,S={1,2,2,2,3,5}。

多重集S 的众数是2,其重数为3。

编程任务:

  对于给定的由n 个自然数组成的多重集S,编程计算S 的众数及其重数。

数据输入:

  输入数据由文件名为input.txt 的文本文件提供。文件的第1 行多重集S 中元素个数n;接下来的n 行中,每行有一个自然数。

结果输出:

  程序运行结束时,将计算结果输出到文件output.txt 中。输出文件有2 行,第1 行给出众数,第2 行是重数。

输入文件示例          输出文件示例

input.txt             output.txt

6                      2

1                      3

2

2

2

3

5

 

代码如下:

#include <iostream>
#include <algorithm>//sort()函数头文件 
using namespace std;
#define N 10000
bool cmp(int a,int b){
    return a<b;
}
int MaxNum=0;  //存储众数大小 
int MaxNumCount=0;  //存储众数个数 
int num[10000];
void split(int left,int right){
    if (left >=right) return;//越界跳出 
    int FirstLeft=left;//记录初始最左侧 
    int FirstRight=right;//记录初始最右侧 
    int mid=(left+right)/2;
    for(;left<mid &&num[left]!=num[mid];left++);//找到中位数的左临界 
    for(;right>mid&&num[right]!=num[mid];right--);//找到中位数的右临界 
    if(MaxNumCount<right-left+1){MaxNum=num[mid];MaxNumCount=right-left+1;} 
  //若此中位数个数大于众数个数,则更新 
  //若中位数左临界左边数字个数小于众数个数,则不需要执行下述操作;中位数右临界数字亦然 
    if(left-FirstLeft>MaxNumCount )split(FirstLeft,left-1);  
    if(FirstRight-right>MaxNumCount)split(right+1,FirstRight);
}
int main()
{
    int n;cin>>n;
    for(int i=0;i<n;i++){
        cin>>num[i];
    }
    sort(num,num+n,cmp);//将数组从小到大排序
    int left0=0;int right0=n-1;
    split(left0,right0);
    cout<<MaxNum<<endl;
    cout<<MaxNumCount<<endl;
    return 0;
}

image.gif


目录
相关文章
|
9月前
|
算法 C语言
分治法——找众数
分治法——找众数
|
4月前
|
算法 开发者 索引
二分算法详解
本文介绍了二分查找及其相关问题的解决方法,包括基本的二分查找、查找元素的第一个和最后一个位置、求平方根、搜索插入位置、寻找峰值和旋转数组中的最小值等问题。通过详细分析每种情况下的二分查找策略,如循环条件、区间划分及特殊情况处理,提供了清晰的代码实现。适用于算法初学者和需要巩固二分查找技巧的开发者。
187 18
二分算法详解
|
9月前
|
存储 算法
二分查找的一种改进-拉格朗日插值查找法
二分查找的一种改进-拉格朗日插值查找法
42 0
27_二叉搜索树的众数
27_二叉搜索树的众数
迭代法解决递推问题:数列和,sinx,ex的近似值
迭代法解决递推问题:数列和,sinx,ex的近似值
143 0
|
9月前
|
算法 Java C++
非启发式算法——二分、三分搜索算法
非启发式算法——二分、三分搜索算法
255 0
分治法求解中位数
分治法求解中位数
88 0
|
Java
寻找两个有序数组的中位数
寻找两个有序数组的中位数
120 0
cf545(线段树 + 离散化)
cf545(线段树 + 离散化)
103 0
|
算法
【leedcode】0004. 两个有序数组的中位数
【leedcode】0004. 两个有序数组的中位数
80 0

热门文章

最新文章