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

本章完。

相关推荐
圣保罗的大教堂40 分钟前
leetcode 1855. 下标对中的最大距离 中等
leetcode
智者知已应修善业2 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-12 小时前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
.5482 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove3 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊3 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
徐某人..3 小时前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
无敌秋4 小时前
# C++ 简单工厂模式实战指南
c++·简单工厂模式
code_pgf4 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源