当前位置:   article > 正文

每日OJ题_算法_模拟④_力扣38. 外观数列

每日OJ题_算法_模拟④_力扣38. 外观数列

目录

力扣38. 外观数列

解析代码


力扣38. 外观数列

38. 外观数列

难度 中等

给定一个正整数 n ,输出外观数列的第 n 项。

「外观数列」是一个整数序列,从数字 1 开始,序列中的每一项都是对前一项的描述。

你可以将其视作是由递归公式定义的数字字符串序列:

  • countAndSay(1) = "1"
  • countAndSay(n) 是对 countAndSay(n-1) 的描述,然后转换成另一个数字字符串。

前五项如下:

1.     1
2.     11
3.     21
4.     1211
5.     111221
第一项是数字 1 
描述前一项,这个数是 1 即 “ 一 个 1 ”,记作 "11"
描述前一项,这个数是 11 即 “ 二 个 1 ” ,记作 "21"
描述前一项,这个数是 21 即 “ 一 个 2 + 一 个 1 ” ,记作 "
  1. 1211"
描述前一项,这个数是 1211 即 “ 一 个 1 + 一 个 2 + 二 个 1 ” ,记作 "111221"

要 描述 一个数字字符串,首先要将字符串分割为 最小 数量的组,每个组都由连续的最多 相同字符 组成。然后对于每个组,先描述字符的数量,然后描述字符,形成一个描述组。要将描述转换为数字字符串,先将每组中的字符数量用数字替换,再将所有描述组连接起来。

例如,数字字符串 "3322251" 的描述如下图:

示例 1:

输入:n = 1
输出:"1"
解释:这是一个基本样例。

示例 2:

输入:n = 4
输出:"1211"
解释:
countAndSay(1) = "1"
countAndSay(2) = 读 "1" = 一 个 1 = "11"
countAndSay(3) = 读 "11" = 二 个 1 = "21"
countAndSay(4) = 读 "21" = 一 个 2 + 一 个 1 = "12" + "11" = "1211"

提示:

  • 1 <= n <= 30
  1. class Solution {
  2. public:
  3. string countAndSay(int n) {
  4. }
  5. };

解析代码

就是一道需要用到双指针的模拟题,考验代码能力

  1. class Solution {
  2. public:
  3. string countAndSay(int n) {
  4. string ret = "1", tmp = "";
  5. int cnt = n;
  6. while(--cnt) // 解释n-1次
  7. {
  8. int len = ret.size();
  9. tmp = "";
  10. for(int left = 0, right = 0; right < len; left = right)
  11. {
  12. while(right < len && ret[left] == ret[right])
  13. { // 双指针计算个数
  14. ++right;
  15. }
  16. tmp += to_string(right - left);
  17. tmp += ret[left];
  18. }
  19. ret = tmp;
  20. }
  21. return ret;
  22. }
  23. };
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/85011
推荐阅读