Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串
来源:互联网 发布:用java编写游戏 编辑:程序博客网 时间:2024/06/07 05:13
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:HappyLetterDiv1Method:getHappyLettersParameters:stringReturns:stringMethod signature:string getHappyLetters(string letters)(be sure your method is public)Limits
Time limit (s):2.000Memory limit (MB):256Notes
-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.
"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 longusing 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; }};
- Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串
- Topcoder Srm 648 DIV1
- Topcoder Srm 649 DIV1
- Topcoder Srm 654 DIV1
- TopCoder SRM 697 div1
- topcoder SRM 501 div1 level1
- TopCoder SRM 474 DIV1 1000
- TopCoder SRM 612 DIV1 900
- TopCoder SRM 144 DIV1 BinaryCode
- TopCoder SRM 512 DIV1 PickAndDelete
- TopCoder SRM 512 DIV1 MysteriousRestaurant
- Topcoder SRM 636 Div1 A
- Topcoder SRM 636 Div1 B
- Topcoder SRM 547 DIV1 Level 1: Pillars
- TopCoder SRM 597 Div1 第1题
- TopCoder SRM 597 Div1 第3题
- TopCoder SRM 598 Div1 第1题
- TopCoder SRM 598 Div1 第2题
- 数据结构实验之栈一:进制转换(难道我学了个假栈?)
- Android Error Gradle sync failed 设备未就绪问题
- 暴力枚举 + 24点 --- hnu : Cracking the Safe
- 扫描线 + 线段树 : 求矩形面积的并 ---- hnu : 12884 Area Coverage
- 枚举 + 进制转换 --- hdu 4937 Lucky Number
- Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串
- Problem--96A--Codeforces--Football
- dp --- hdu 4939 : Stupid Tower Defense
- STL : map函数的运用 --- hdu 4941 : Magical Forest
- N阶幻方入门算法及图解
- 拓扑排序 --- hdu 4948 : Kingdom
- 每日练习(6)
- 计算几何 : 凸包学习笔记 --- Graham 扫描法
- 计算几何 --- 凸包 模板