Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串

简介: Problem Statement      The Happy Letter game is played as follows: At the beginning, several players enter the field.

Problem Statement

    

The Happy Letter game is played as follows: At the beginning, several players enter the field. Each player has a lowercase English letter on their back. The game is played in turns. In each turn, you select two players with different letters, and both selected players leave the field. The game ends once it is impossible to take another turn.

If there are some players left in the field at the end of the game, they must all have the same letter. That letter is called the winning letter. If there are no players left in the field at the end of the game, there is no winning letter.

You are given a string letters. The characters in letters are the characters carried by the players at the beginning of the game. Return a string with all possible winning letters. The letters in the returned string must be sorted in increasing order.

Definition

    
Class: HappyLetterDiv1
Method: getHappyLetters
Parameters: string
Returns: string
Method signature: string getHappyLetters(string letters)
(be sure your method is public)

Limits

    
Time limit (s): 2.000
Memory limit (MB): 256

Notes

- If there's no happy letter, return the empty string.

Constraints

- letters will contain between 1 and 50 elements.
- Each element of letters will be a lowercase English letter ('a'-'z').

Examples

0)  
    
"aabbacccc"
Returns: "abc"
Each of the three letters can be the winning letter. Here is one possibility how 'a' can be the winning letter: Let's number the players 0 through 8 in the order in which they appear in the input. We can then play the game as follows:
  • Send away players 1 ('a') and 8 ('c').
  • Send away players 2 ('b') and 6 ('c').
  • Send away players 7 ('c') and 0 ('a').
  • Send away players 5 ('c') and 3 ('b').
  • The only player left is player 4 ('a'), hence 'a' is the winning letter.
1)  
    
"aaaaaaaccdd"
Returns: "a"
Only letter 'a' can win.
2)  
    
"ddabccadb"
Returns: "abcd"
 
3)  
    
"aaabbb"
Returns: ""
No letter can win.
4)  
    
"rdokcogscosn"
Returns: "cos"
 

 

Mean:

 

给你一个只有小写字母组成的字符串,每一轮你可以选择两个不相同的字符删去,如果最后还有剩下的字符,那么这个字符就是winning letter,现在要你返回可能是winning letter的字符组成的字符串,并按照升序排序。

 

 

analyse:

 

我们首先将每个字母出现的次数统计一遍,然后就是对26个小写字母进行判断,如果不包括本身,最多数量的那个字符的数量大于剩余字符的数量,说明不可能满足题目的要求(不同的字符相互匹配),否则就符合题目要求,加入ans字符串即可。

 

 

Time complexity:O(n)

 

Source code:

 

// BEGIN CUT HERE

// END CUT HERE
#line 5 "HappyLetterDiv1.cpp"
//Memory   Time
//  K      MS
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<vector>
#include<queue>
#include<stack>
#include<iomanip>
#include<string>
#include<climits>
#include<cmath>
#define MAX 1100
#define LL long long
using namespace std;

class HappyLetterDiv1 {
    public:
    string getHappyLetters(string letters) {
        string ans;
        ans.clear();
        int len=letters.size();
        int cnt[30]={0};
        for(int i=0;i<len;i++)
            cnt[letters[i]-'a']++;
        for(int i=0;i<26;i++)
        {
            if(cnt[i])
            {
                if(cnt[i]==1&&!(len&1))
                    continue;
                int maxx=-1;
                for(int j=0;j<26;j++)
                    if(j!=i)
                        maxx=max(maxx,cnt[j]);
                if(maxx<=len-1-maxx)
                    ans+='a'+i;
            }
        }
        return ans;
    }
};

  

目录
相关文章
|
6月前
|
数据安全/隐私保护
【鸿蒙软件开发】文本输入(TextInput/TextArea)
【鸿蒙软件开发】文本输入(TextInput/TextArea)
1055 0
|
1月前
|
小程序
微信小程序之weui.wxss不能引用查找的解决方案
微信小程序之weui.wxss不能引用查找的解决方案
48 0
|
5月前
|
JSON PHP 数据格式
php 富文本双引号问题,将双引号变为&quot;html转义入库
php 富文本双引号问题,将双引号变为&quot;html转义入库
51 0
|
6月前
关于解决el-select组件自动清除数据空格的问题
关于解决el-select组件自动清除数据空格的问题
201 1
|
JavaScript jenkins Linux
Vue整合element-china-area-data实现PC端省市区三级联动选择器
demo环境是SpringBoot+Vue+elementUI,开发工具是idea,有涉及到省市区三级联动选择器,网上查找了下,发现了这款和elementUI相匹配的element-china-area-data,这样的话样式什么的就不用担心会很丑,也不需要调,最主要是还可以直接获取到省市区编码,都不用通过后台接口转换。于是就撸起袖子,满心欢喜的整进来。
1955 0
Vue整合element-china-area-data实现PC端省市区三级联动选择器
|
开发者
华为快应用-在卡片中使用lines限制text行数无效的问题
华为快应用-在卡片中使用lines限制text行数无效的问题
115 0
|
JavaScript
VUE element-ui之table表格内容添加千位分割符/货币格式
VUE element-ui之table表格内容添加千位分割符/货币格式
557 0
VUE element-ui之table表格内容添加千位分割符/货币格式
SAP WM 显示TR ITEM的标准报表LX09
SAP WM 显示TR ITEM的标准报表LX09
SAP WM 显示TR ITEM的标准报表LX09