• 算法训练 出现次数最多的整数


    问题描述
      编写一个程序,读入一组整数,这组整数是按照从小到大的顺序排列的,它们的个数N也是由用户输入的,最多不会超过20。然后程序将对这个数组进行统计,把出现次数最多的那个数组元素值打印出来。如果有两个元素值出现的次数相同,即并列第一,那么只打印比较小的那个值。
      输入格式:第一行是一个整数NN £ 20;接下来有N行,每一行表示一个整数,并且按照从小到大的顺序排列。
      输出格式:输出只有一行,即出现次数最多的那个元素值。
    输入输出样例
    样例输入
    5
    100
    150
    150
    200
    250
    样例输出
    150
     
    注意:
    1.n的可能取值在整数范围内,存在<=0的情况
    2.注意最后一个元素的判断
     
    #include<cstring>
    #include<algorithm>
    #include<cstdio>
    #include<iostream>
    using namespace std;
    int main(void){
        long long n,data,count=1,a[21],count_max=0;
        cin >> n;
        if(n <= 0) return 0;
        for(int i=1;i<=n;i++){
            cin >> a[i];
        }
        data = a[1];
        count = 1;
        for(int i=2;i<=n;i++){
            if(a[i] != a[i-1]){
                if(count_max < count){
                    count_max = count;
                    data = a[i-1];
                }
                count = 1;
            }else count++;
            if(i == n){
                if(count_max < count){
                    count_max = count;
                    data = a[n]; 
                }
            }
        }
        cout << data;
        return 0;
    } 
  • 相关阅读:
    MVC三层架构学习总结实例
    JSON & Ajax
    设计模式之单例模式
    设计模式之静态工厂方法
    Gitee 添加了ssh公钥还是需要账户和密码
    MySQL日期时间函数大全[转]
    session 注意事项
    session 入库2 垃圾回收机制
    session 入库的实现
    PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
  • 原文地址:https://www.cnblogs.com/zuimeiyujianni/p/8503962.html
Copyright © 2020-2023  润新知