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];
    }
};
相关推荐
happymaker06261 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊1 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
八解毒剂3 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录3 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz3 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058194 小时前
python语法
开发语言·python·算法
DXM05214 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉
小蒋学算法4 小时前
算法-阶乘函数后K个零
算法
weixin_307779134 小时前
智能模拟数据生成平台:生成式AI合成数据技术重塑开发测试效能
人工智能·测试工具·算法·测试用例
li星野4 小时前
从零构建安全文件上传系统:FastAPI + JWT + 密码哈希 + Streamlit 前端 + SQLite
安全·哈希算法·fastapi