leetcode 38 外观数列

一、题目描述

二、解题思路

整体思路

可以采用模拟+双指针的方法来解决这个题目。

具体思路

(1)返回数列的第n项,需要描述n-1次;

(2)定义变量left和right充当双指针,ret[left]就是字符的种类,right-left就是该字符出现的次数,将二者转成字符串,然后加入tmp字符串;

(3)ret字符串遍历完成后,将ret更新为tmp字符串,直到描述完n-1次,返回ret即可。

三、代码实现

cpp 复制代码
class Solution {
public:
    string countAndSay(int n) {
      //模拟+双指针
      string ret="1";
      //描述n-1次
      for(int i=1;i<n;i++){
        string tmp;
        for(int left=0,right=0;right!=ret.size();){
            while(ret[left]==ret[right]) right++;
            tmp+=to_string(right-left)+ret[left];
            left=right;
        }
        ret=tmp;
      }
      return ret;
    }
};
相关推荐
xu_yule10 小时前
算法基础—组合数学
c++·算法
爱尔兰极光10 小时前
LeetCode--移除元素
算法·leetcode·职场和发展
Tansmjs11 小时前
C++中的工厂模式变体
开发语言·c++·算法
naruto_lnq11 小时前
多平台UI框架C++开发
开发语言·c++·算法
Tingjct11 小时前
十大排序算法——交换排序(一)
c语言·开发语言·数据结构·算法·排序算法
爱装代码的小瓶子11 小时前
【C++与Linux基础】文件篇(8)磁盘文件系统:从块、分区到inode与ext2
linux·开发语言·c++
MM_MS11 小时前
Halcon图像点运算、获取直方图、直方图均衡化
图像处理·人工智能·算法·目标检测·计算机视觉·c#·视觉检测
每天要多喝水11 小时前
贪心算法专题Day22
算法·贪心算法
ujainu11 小时前
Flutter + OpenHarmony 游戏开发进阶:动态关卡生成——随机圆环布局算法
算法·flutter·游戏·openharmony
PPPPPaPeR.11 小时前
程序地址空间
linux·算法