zoukankan      html  css  js  c++  java
  • 输出众数,输出超限问题

    http://zju.acmclub.com/index.php?

    app=problem_title&id=1&problem_id=1968

    题目非常easy。给定20个数,输出众数,假设出现次数相等就输出值小的那个。

    值得一提的是:之前把cin>>x放在了while(1)里面,一直提示输出超限

    后来偷偷看了一下标程。发现直接while(cin>>x)。看来须要保证while循环总是能够退出,涨姿势了。

    处理方法就是:首先最外层的循环用while(cin>>x)先读取第一个数并处理,假设第一个数能读进来再读剩下的数。

    最后把两次遍历改成一次遍历,果断AC。。

    cpp代码:

    #include<iostream>
    using namespace std;
    int main(){
        int x,i,MAX,keep;
        int num[11];
        while(cin>>x){//先读第一个元素并处理,避免输出超限
            for(i=0;i<11;i++)num[i]=0;
            num[x]++;
            MAX=num[x];
            keep=x;
            for(i=1;i<20;i++){
                cin>>x;
                num[x]++;
                if(num[x]>=MAX){
                    if(num[x]==MAX){
                        if(x<keep)keep=x;
                    }
                    else{
                        MAX=num[x];
                        keep=x;
                    }
                }
            }
            cout<<keep<<endl;
        }
        return 0;
    }
    


  • 相关阅读:
    javascript之理解参数按值传递
    javascript之模仿jQuery实现框架雏形
    javascript之正则表达式学习笔记
    python常用算法了解
    爬虫_小结04
    爬虫_小结03
    爬虫_小结02
    爬虫_小结01
    IO 模型
    数据库,前端和框架须知
  • 原文地址:https://www.cnblogs.com/jzssuanfa/p/6953775.html
Copyright © 2011-2022 走看看