LeetCode模拟算法精解II:外观数列与数青蛙

上篇文章:LeetCode模拟算法精解I:替换问号,提莫攻击与Z字形变换

目录

1.外观数列

理解题意

算法原理

2.数青蛙

理解题意

算法原理


1.外观数列

https://leetcode.cn/problems/count-and-say/description/

理解题意

  1. 给一个数,这个数是1
  2. 描述上一步的数,这个数是 1 即一个1,故写作11
  3. 描述上一步的数,这个数是11即两个1,故写作21
  4. 描述上一步的数,这个数是21即一个2一个1,故写作12-11
  5. 描述上一步的数,这个数是1211即一个1一个2两个1,故写作11-12-21

算法原理

通过模拟和双指针,对给定的数字进行解释。

复制代码
class Solution 
{
public:
    string countAndSay(int n) 
    {
        string ret = "1";
        for(int i = 1; i < n; i++) // 遍历
        {
            string tmp;
            int len = ret.size();
            for(int left = 0, right = 0; right < len; ) // 解释ret
            {
                while(right < len && ret[left] == ret[right])
                {
                    right++;
                }
                tmp += to_string(right - left) + ret[left];
                left = right;
            }
            ret = tmp;
        }
        return ret;
    }
};

2.数青蛙

https://leetcode.cn/problems/minimum-number-of-frogs-croaking/description/

理解题意

计算在字符串中字符c,r,o,a,k出现的次数,只要顺序不变,出现次数合理,哪怕有若干个随意穿插,也属于有效字符。

算法原理

本题要求出现次数以及确定顺序和重复度,所以使用哈希表(数组模拟实现)进行判断。

基本判断如下:

复制代码
class Solution 
{
public:
    int minNumberOfFrogs(string croakOfFrogs) 
    {
        string t = "croak";
        int n = t.size();
        vector<int> hash(n); // 数组模拟哈希表

        unordered_map<char, int> index; // 字符对应下标
        for(int i = 0; i < n; i++)
        {
            index[t[i]] = i;
        }

        for(auto ch : croakOfFrogs)
        {
            if(ch == 'c')
            {
                if(hash[n - 1] != 0) hash[n - 1]--;
                hash[0]++;
            }  
            else
            {
                int i = index[ch];
                if(hash[i - 1] == 0) return -1;
                hash[i - 1]--; hash[i]++;
            }
        }

        for(int i = 0; i < n - 1; i++)
        {
            if(hash[i] != 0)
                return -1;
        }
        return hash[n - 1];
    }
};

本章完。

相关推荐
小欣加油27 分钟前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
星恒随风1 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
浪客灿心2 小时前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q2 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
happymaker06263 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊4 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
烬羽4 小时前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
YHL4 小时前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
为何创造硅基生物4 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
JieE2124 小时前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试