leetcode 38. 外观数列(medium)(优质解法)

链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

代码:

java 复制代码
class Solution {
    public String countAndSay(int n) {
        //要进行 n - 1 次描述才能得到结果
        // last 代表当前要描述的字符串
        String last="1";
        // ret 代表描述 last 字符串得到的结果
        for(int i=1;i<n;i++){
             StringBuilder ret=new StringBuilder();
            //进行描述
            int length=last.length();
            for(int left=0,right=0;left<length&&right<length;){
                while(right<length&&last.charAt(left)==last.charAt(right)){
                    right++;
                }
                //将个数拼接到 ret 字符串上
                ret.append(right-left);
                //将个数对应的字符拼接到 ret 字符串上
                ret.append(last.charAt(left));
                left=right;
            }

            //进行了一轮描述
            last=ret.toString();
        }

        return last;
    }
}

题解:

本题的解法比较简单粗暴,直接按照题目的要求进行模拟即可

先要搞明白如何描述一个数字字符串,我们可以通过双指针来进行描述,比如有字符串 11222 需要我们进行描述,描述的结果应为 2132

先让 L 和 R 指针指向下标为 0 的位置,描述的核心就是要获得连续字符的个数,首先判断 R 指针和 L 指针指向的数据是否相同,相同 R 指针就向后移

1 1 2 2 2

L

R

根据上述要求,R 指针移动到当前位置,此时 R 指针指向的数据和 L 指针指向的不同,L 指针指向的就是当前数的数据,个数为 R - L,将个数和数据拼接到字符串中,得到 21

1 1 2 2 2

L

R

L 指针指向的数据已经数好了,让 L 指针移动到 R 指针所在的位置,数下一个连续数据的个数

1 1 2 2 2

L

R

同理,当 L 和 R 指针相同 R 指针就向后移动,要注意边界,R 指针移动到字符串边界时要停止,得到数据 2 个数 R - L = 3 ,将其拼接到字符串中得到 2132

1 1 2 2 2

L

R

知道如何描述,以及一开始描述的数据为 1,便知道描述 n -1 次后得到的数据为多少

相关推荐
xwz小王子40 分钟前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
拼尽全力前进1 小时前
Guava Cache vs Caffeine 面试详解
面试·职场和发展·guava
黎阳之光2 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
程序员小远2 小时前
Python自动化测试框架及工具详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
Black蜡笔小新2 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手2 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈3 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet3 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农3 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li3 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法