zoukankan      html  css  js  c++  java
  • 杭电1004 Let the Balloon Rise

    Let the Balloon Rise

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 120507    Accepted Submission(s): 47270


    Problem Description
    Contest time again! How excited it is to see balloons floating around. But to tell you a secret, the judges' favorite time is guessing the most popular problem. When the contest is over, they will count the balloons of each color and find the result.

    This year, they decide to leave this lovely job to you. 
     
    Input
    Input contains multiple test cases. Each test case starts with a number N (0 < N <= 1000) -- the total number of balloons distributed. The next N lines contain one color each. The color of a balloon is a string of up to 15 lower-case letters.

    A test case with N = 0 terminates the input and this test case is not to be processed.
     
    Output
    For each case, print the color of balloon for the most popular problem on a single line. It is guaranteed that there is a unique solution for each test case.
     
    Sample Input
    5 green red blue red red 3 pink orange pink 0
     
    Sample Output
    red pink
     
     
     
      题目大意:这题相当于是一个配对问题,一个ball的颜色对应一个个数。
      解题思路:这题大体的解题思路是一致的,就是一种颜色要去对应一个数。然后我提供两种方法:
    第一种:通过STL的map<string,int>的key-value 对应的值来求解,这里面还用到了pair转化为vector的方法,还有一些对sort排序map的扩展(MMP,就是应为这个,我以为sort(begin,end)就行,结果是不能这么玩的,必须多加一个参数)。代码如下:
    #include <iostream>
    #include<stdlib.h>
    #include<string>
    #include<map>
    #include<vector>
    #include<algorithm>
    
    using namespace std;
    
    typedef pair<string,size_t> PAIR;
    
    //定义排序比较函数,通过value比较
    bool cmp_by_value(const PAIR& lhs, const PAIR& rhs) {  
        return lhs.second > rhs.second;  
    }
    
    int main(void)
    {
        int n;
        map<string,size_t>color_balloon;
        string * input_str;
    
        while(cin>>n&&n)
        {
            input_str=new string[n];//为输入的颜色分配空间
            for(int i=0;i<n;i++)
            {
                cin>>input_str[i];
                ++color_balloon[input_str[i]];//提取input_str[]计数器并对其加1
            }
            //把map中元素转存到vector中
            vector <PAIR> color_str_vec(color_balloon.begin(),color_balloon.end());
            //按降序排序
            sort(color_str_vec.begin(),color_str_vec.end(),cmp_by_value);
            //color_str_vec已经按照降序排序,输出第一个即为出现次数最多的一个
            cout<<color_str_vec[0].first<<endl;
            //必须清空
            color_balloon.clear();
            delete [] input_str;
        }
        return 0;
    }

    代码中知识参考:

    思路供给:http://blog.csdn.net/always2015/article/details/44975799

    map的比较函数那个知识,还有pair转化为vec的用法:http://www.cnblogs.com/fengting/p/5847347.html

    第二种:

    我用两个数组,一个数组用来存放字符串,一个数组用来存放对应字符串的出现次数。然后算法实现基本为:输入一个字符串,我先在之前的存入的字符串中找。如果找到了,那么该字符串对应的num++,如果找不到,那就把这个字符串作为一个新的字符串插入到字符串数组中,并且其num[i]++(从0变为1)。然后就是简单的排序输出。这个思路还是很清晰的。代码如下:

    #include <iostream>
    #include<math.h>
    #include <iomanip>
    #include<cstdio>
    #include<string>
    #include<map>
    #include<vector>
    #include<list>
    #include<algorithm>
    #include<stdlib.h>
    #include<iterator>
    #include<sstream>
    #include<string.h>
    using namespace std;
    
    
    int main()
    {
        int n;
    
    
        while(cin>>n)
        {
             string input[1002];//初始化最好在循环里弄 没那么多屁事
        for(int u=0;u<1002;u++)
            input[u]=" ";
        int num[1002]={0};
            string temp;
            int i,j;
            for(i=0;i<n;i++)//开始实现算法
            {
                cin>>temp;//读一个字符串
                for(j=0;j<i;j++)//在已经输入的 字符串数组中找 有没有一样的
                {
                    if(temp==input[j])
                    {
                        num[j]++;//有的话 对应的下标++ !!!!注意 这边是J++ 因为是在已经存在的数组中找
                        break;
                    }
                }
                if(i==j)//找不到 说明 没有 那就是多了一种颜色 那就要把新颜色加入到数组中去
                {
                    input[i]=temp;
                    num[i]++;//然后别忘记对应的 数字++
                }
            }
    
            int max=0;
            for(i=0;i<n;i++)//排序 
            {
                if(num[i]>num[max])
                {
                    max=i;
                }
            }
            cout<<input[max]<<endl;//输出
    
    
    
        }
    
        return 0;
    }
    注意,以后没有很强的时间要求,那就把所有初始化,都放在循环中,这样就省了初始化了。
  • 相关阅读:
    ROSS仿真系统简单教程
    python小练习1.1
    c语言文件I/O 文件读取和写入
    Python 学习笔记 多线程-threading
    parsec(The parsec benchmark suit )使用教程
    Checkpoint/Restore In Userspace(CRIU)使用细节
    Checkpoint/Restore in Userspace(CRIU)安装和使用
    考研总结
    北理计算机复试经验
    PAT(A) 1075. PAT Judge (25)
  • 原文地址:https://www.cnblogs.com/William-xh/p/6901200.html
Copyright © 2011-2022 走看看