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];
    }
};
相关推荐
杨小码不BUG8 分钟前
Davor的北极探险资金筹集:数学建模与算法优化(洛谷P4956)
c++·算法·数学建模·信奥赛·csp-j/s
mit6.82430 分钟前
10.5 数位dp
c++·算法
2401_881244402 小时前
P3808 AC 自动机(简单版)
算法
Jayden_Ruan2 小时前
C++十进制转二进制
数据结构·c++·算法
Haooog2 小时前
98.验证二叉搜索树(二叉树算法题)
java·数据结构·算法·leetcode·二叉树
Macre Aegir Thrym3 小时前
MINIST——SVM
算法·机器学习·支持向量机
Young_Zn_Cu4 小时前
LeetCode刷题记录(持续更新中)
算法·leetcode
天选之女wow4 小时前
【代码随想录算法训练营——Day31】贪心算法——56.合并区间、738.单调递增的数字、968.监控二叉树
算法·leetcode·贪心算法
lixinnnn.4 小时前
贪心:火烧赤壁
数据结构·c++·算法
小小前端_我自坚强5 小时前
前端算法相关详解
前端·算法