[Leetcode]_38 Count and Say

/**
 *  Index: 38
 *  Title: Count and Say
 *  Author: ltree98
 **/



题目意思是,输出某序列的值。
这个序列,有些类似于 斐波那契数列 —— 后面的值由前面的值决定。

index   ->      ans     |   规则(后面的根据上一个,连续的数字做组合)
1       ->      1       |   第一个 
2       ->      11      |   前一个 1,只有一部分,1111
3       ->      21      |   前一个,就是 11; 连续的数字看做一组来读, 所以只有一部分, 2121
4       ->      1211    |   两部分, 21; 12121111; 连起来 1211
5       ->      111221  |   分成3部分, 1211111112122121; 连起来 111221
6       ->      312211  |   分成3部分, 111221313122221111; 连起来 312211
...

总结起来,就是先把前一个分成几个部分,然后开始读,最后拼起来。
再总结就是,
1、把前一个字符串从前开始读,如果下一个字符和本个字符一样,继续读,并记录数量,直到不一样。
2、读一下,记录到答案中
3、回到第1步


class Solution {
public:
    string countAndSay(int n) {
        if(n <= 1) 
            return "1";

        string pre = countAndSay(n-1);
        string ans = "";

        for(int i = 0; i < pre.length(); )  {
            int j = i+1;
            for(; j < pre.length(); j++)
                if(pre[i] != pre[j])
                    break;
            int n = j-i;
            ans = ans + to_string(n) + pre[i];
            i = j;
        }
        return ans;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值