1419. Minimum Number of Frogs Croaking

  • 找规律
  • 从后向前思考,有 k 时必须有 a,有 a 时前面必须有 o,并且一一对应
  • 由此构建哈希表,比如出现 k,则出现 a 的次数减一,k 则加一
  • 处理 c 的起始情况
  • 异常情况的判断:若出现 roak中的一个,前面没有与之对应的前一个字符,则返回-1;
  • 最后返回值为 k 的个数,前提是此时哈希表中其他字符计数为0
cpp 复制代码
class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        string s = "croak";
        unordered_map<char, int> index; // 每个字符与下标映射
        for(int i = 0; i < s.size(); i++)
            index[s[i]] = i;
        vector<int> hash(s.size());
        for(int i = 0; i < croakOfFrogs.size(); i++)
        {
            if(croakOfFrogs[i] == s[0])
            {
                if(hash[s.size() - 1] != 0)
                    hash[s.size() - 1]--;
                hash[0]++;
            }
            else
            {
                if(hash[index[croakOfFrogs[i]] - 1] == 0)
                    return -1;
                hash[index[croakOfFrogs[i]] - 1]--;
                hash[index[croakOfFrogs[i]]]++;

            }
        }
        for(int i = 0; i < s.size() - 1; i++)
        {
            if(hash[i] != 0)
                return -1;
        }
        return hash[s.size() - 1];
    }
};
相关推荐
小灰灰爱代码5 小时前
C++——将数组a[5]={-1,2,9,-5,7}中小于0的元素置成0。并将其结果输出(要求:用数组名作为函数的参数来实现)
数据结构·c++·算法
liuyang-neu6 小时前
力扣中等 33.搜索旋转排序数组
java·数据结构·算法·leetcode
ganjiee00077 小时前
力扣(leetcode)每日一题 2414 最长的字母序连续子字符串的长度
java·算法·leetcode
ly-how7 小时前
leetcode练习 格雷编码
数据结构·算法·leetcode
阿W呀7 小时前
MATLAB-最小二乘辨识
人工智能·算法·matlab
liuyang-neu7 小时前
力扣 中等 162.寻找峰值
数据结构·算法·leetcode
scott1985127 小时前
张正友相机标定算法
数码相机·算法
临江浪怀柔ℳ7 小时前
tb的数数问题(牛客小白月赛)
算法
我只钓小鱼7 小时前
蚁群算法+A*算法寻找多目标最优路径
算法
月下绯烟7 小时前
chapter14 数据结构与集合源码 知识点总结Note
java·数据结构·算法