题目描述:
给定两个整数 A 和 B,返回任意字符串 S,要求满足:
S 的长度为 A + B,且正好包含 A 个 ‘a’ 字母与 B 个 ‘b’ 字母;
子串 ‘aaa’ 没有出现在 S 中;
子串 ‘bbb’ 没有出现在 S 中。
示例 1:
输入:A = 1, B = 2
输出:“abb”
解释:“abb”, “bab” 和 “bba” 都是正确答案。
示例 2:
输入:A = 4, B = 1
输出:“aabaa”
提示:
0 <= A <= 100
0 <= B <= 100
对于给定的 A 和 B,保证存在满足要求的 S。
方法1:
主要思路:解题汇总链接
(1)使用贪心思想;
(2)生成字符串时,将字符较多的字符放到前面,较少的放到后面,先尽量的方AABB形式(若A较多),再考虑AAB的形式,最后求剩余的字符的组成,可能AA,或AAB等;
class Solution {
public:
void get_str(int bigger,char ch_1,int smaller