LeetCode 1419.数青蛙

90 阅读1分钟

从零开始学习c++,每天起码做一道leetcode题目,在此记录,希望最后能够有所收获!

一、题目描述

1419.数青蛙

给你一个字符串 croakOfFrogs,它表示不同青蛙发出的蛙鸣声(字符串 "croak" )的组合。由于同一时间可以有多只青蛙呱呱作响,所以 croakOfFrogs 中会混合多个 “croak” 。

请你返回模拟字符串中所有蛙鸣所需不同青蛙的最少数目。

要想发出蛙鸣 "croak",青蛙必须 依序 输出 ‘c’, ’r’, ’o’, ’a’, ’k’ 这 5 个字母。如果没有输出全部五个字母,那么它就不会发出声音。如果字符串 croakOfFrogs 不是由若干有效的 "croak" 字符混合而成,请返回 -1 。

示例 1:

输入: croakOfFrogs = "croakcroak"
输出: 1 
解释: 一只青蛙 “呱呱” 两次

示例 2:

输入:croakOfFrogs = "crcoakroak"
输出:2 
解释:最少需要两只青蛙,“呱呱” 声用黑体标注
第一只青蛙 "crcoakroak"
第二只青蛙 "crcoakroak"

示例 3:

输入: croakOfFrogs = "croakcrook"
输出: -1
解释: 给出的字符串不是 "croak " 的有效组合。

提示:

  • 1 <= croakOfFrogs.length <= 105
  • 字符串中的字符只有 'c''r''o''a' 或者 'k'

二、思路分析

题目意思没有理解好,导致走了弯路。

要注意的是如果没有依序输出全部五个字母,那么它就不会发出声音。且如果字符串不是由若干个有效的“croak”混合而成,请返回-1.

本题需要一个数组记录五个字母出现的次数,且每遍历到字符串的一个字符时,它前面的字符都应该大于0,除非该字符为c,是c的话且k为0了那么就说明需要一只新的青蛙来叫。

最后看k是多少,就是有多少只青蛙。

三、AC代码

class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        unordered_map<char,char>t={{'c','k'},{'r','c'},{'o','r'},{'a','o'},{'k','a'}};
        int ans['s']={0};
        for(auto &ch:croakOfFrogs){
            char pre=t[ch];
            if(ans[pre]){
                ans[pre]--;
            }
            else if(ch!='c'){
                return -1;
            }
            ans[ch]++;
        }
        if(ans['a']!=0||ans['o']!=0||ans['r']!=0||ans['c']!=0){
            return -1;
        }
        return ans['k'];           
    }
};

四、总结

没做出来,感觉题目的理解有一定难度。