【剑斩OFFER】算法的暴力美学——数青蛙

一、题目描述

二、算法原理

我们用一个哈希表来统计 croak 每个字符出现的次数,我们重头开始遍历原数组,我们先聊一下除了遍历到字符 "c" 的情况:

假设我们遍历到字符 "r" ,我们先看一下 "r" 前面的 "c" 出现的次数,如果等于0,表示没有青蛙叫出:"c",这是违规的,所以我们要返回 -1,不等于0,那么前面出现的字符 "c" 次数减1,当前字符 "r" 在哈希表的次数要加一。

重复上面的操作,当我们遍历一个完整的 croak 字符串时,字符 'k' 的次数为1,所以当我们再次遍历到字符 "c" 时,我们先要看的是 "k" 字符的次数是否为0,如果等于0,那么代表没有青蛙完整的叫出 croak ,所以我们要让 "c" 字符在哈希表的次数加1,反之我们要让 "k" 在哈希表的次数减1,而字符 "c" 在哈希表的次数要加1,代表着我们要完整的叫出 croak 的青蛙重新开始叫,所以我们要 "k" 在哈希表的次数减1。

一套操作下来,哈希表的情况应该是 "k" 有次数,而其他的字符都为0,如果其他的字符不为0,这代表着有青蛙没有完整的叫出来,此时返回 -1.

三、代码实现

cpp 复制代码
class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        unordered_map<char,int> hash;
        unordered_map<char,int> tmp;
        string s = "croak";
        for(int j = 0;j < s.size();j++)
        {
            tmp[s[j]] = j;//保存该字符的下标,当我们查找他上一个的字符时可以快速找到
            hash[s[j]] = 0;
        }

        for(int i = 0; i < croakOfFrogs.size();i++)
        {
            char ch = croakOfFrogs[i];
            if(ch == 'c')
            {
                if(hash['k'])
                {
                    hash['k']--;
                    hash[ch]++;
                }
                else
                    hash[ch]++;
            }
            else
            {
                int prech = tmp[ch] - 1;//该字符的上一个字符的下标
                if(hash[s[prech]])//该字符的上一个字符存在
                {
                    hash[s[prech]]--;
                    hash[ch]++;
                }
                else return -1;//不存在,则代表前面没有青蛙叫,这就是违规情况
            }
        }
        for(int i = 0; i < s.size() - 1;i++)
        {
            if(hash[s[i]]) return -1;//表示除 "k" 之外的还要字符被叫了,但是没有叫出完整的 croak
        }
        return hash['k'];//"k" 表示有多少个字符完整的叫出 croak
    }
};
相关推荐
ZHW_AI课题组9 分钟前
基于逻辑回归的乳腺癌预测分类
算法·分类·逻辑回归
胡志辉14 分钟前
贪心算法最坑的地方:每一步都看起来很对,最后还是错了
算法
代码北人生18 分钟前
GitHub 日榜第一、月下载 110 万:supervision 出现之前,写计算机视觉代码是什么感觉
算法·claude
南宫萧幕22 分钟前
HEV能量管理策略 Simulink 实战:从零搭建 Rule-based 与 A-ECMS 对比模型及排错指南
人工智能·算法·matlab·simulink·控制
WBluuue1 小时前
Codeforces 1095 Div2(ABCDE)
c++·算法
IT当时语_青山师__JAVA技术栈1 小时前
数组与链表深度解析:从内存布局到工业级实践
java·算法·面试
吃着火锅x唱着歌1 小时前
LeetCode 496.下一个更大元素I
算法·leetcode·职场和发展
不知名的忻1 小时前
关键路径(Java)
java·数据结构·算法·关键路径
大大杰哥1 小时前
2025ccpc南昌补题笔记(前六题)
c++·笔记·算法
手写码匠1 小时前
手写 AI 智能路由系统:从零构建多模型调度与负载均衡
人工智能·深度学习·算法·aigc