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];
    }
};

本章完。

相关推荐
赫瑞20 分钟前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背25 分钟前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
初夏睡觉1 小时前
c++1.3(变量与常量,简单数学运算详解),草稿公放
开发语言·c++
西岸行者1 小时前
BF信号是如何多路合一的
算法
阿拉斯攀登1 小时前
从入门到实战:CMake 与 Android JNI/NDK 开发全解析
android·linux·c++·yolo·cmake
大熊背1 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考2 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef063 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi4 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
筱璦4 小时前
期货软件开发 - C# 调用 HQChart 指标计算 C++ 动态库
c++·microsoft·c#