我是靠谱客的博主 大意溪流,最近开发中收集的这篇文章主要介绍杭电1004 Let the Balloon RiseLet 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;
}

 

注意,以后没有很强的时间要求,那就把所有初始化,都放在循环中,这样就省了初始化了。

 

转载于:https://www.cnblogs.com/William-xh/p/6901200.html

最后

以上就是大意溪流为你收集整理的杭电1004 Let the Balloon RiseLet the Balloon Rise的全部内容,希望文章能够帮你解决杭电1004 Let the Balloon RiseLet the Balloon Rise所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部