【算法】模拟算法——数青蛙(medium)

简介: 【算法】模拟算法——数青蛙(medium)

题解:模拟算法——数青蛙(medium)

1.题目

题目链接:LINK

2.题解

用循环进行遍历,

  • 如果该字符为o\o\a\k 找一下前驱字符是否存在
  • 如果存在,前驱字符–,该字符++
  • 如果不存在,返回-1
  • 如果该字符为c,找一下最后一个字符是否有数
  • 如果最后一个数非0,最后一个字符–,当前字符++
  • 最后一个数是0,当前字符++

3.参考代码

不用哈希表,缺点是这个字符串字符种类太多时会不适用。

class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        //哈希数组
        int arr[5] = {0};//c r o a k
        //0标识c,1标识r,2标识o,3标识a,4标识k
        for(auto& ch: croakOfFrogs)
        {
            if(ch == 'c')
            {
                if(arr[4] == 0) arr[0]++;
                else arr[4]--,arr[0]++;
            }
            else if(ch == 'r')
            {
                if(arr[0] != 0) arr[0]--,arr[1]++;
                else return -1;
            }
            else if(ch == 'o')
            {
                if(arr[1] != 0) arr[1]--,arr[2]++;
                else return -1;
            }
            else if(ch == 'a')
            {
                if(arr[2] != 0) arr[2]--,arr[3]++;
                else return -1;
            }
            else if(ch == 'k')
            {
                if(arr[3] != 0) arr[3]--,arr[4]++;
                else return -1;
            }
        }
        if((arr[0] + arr[1] + arr[2] + arr[3]) != 0) return -1;
        
        return arr[4];
    }
};

用哈希表,好处是可以适用字符串字符种类很大的时候

class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        string s = "croak";
        int n = s.size();
        //哈希数组
        int hash[5] = {0};//c r o a k
        //0标识c,1标识r,2标识o,3标识a,4标识k
        //为了方便找到前一个字母的下标,我们用哈希表来记录一下
        unordered_map<char,int> index;
        for(int i = 0; i < n; i++)
        {
            index[s[i]] = i;
        }
        for(auto& ch: croakOfFrogs)
        {
            if(ch == 'c')
            {
                if(hash[n-1] == 0) hash[0]++;
                else hash[n-1]--,hash[0]++;
            }
            else
            {
                int i = index[ch];//取到该字符对应的下标
                if(hash[i-1] != 0) hash[i-1]--,hash[i]++;
                else return -1;
            }
        }
        for(int i = 0; i < n-1; i++)
        if(hash[i]!=0) return -1;
        return hash[n-1];
    }
};

这个地方为什么用哈希表呢?主要是为了方便找到对应字符的下标。

4.总结

这个题的解题思路挺好,然后用哈希表存下标写代码是一个不错的选择。


EOF

相关文章
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
算法
【算法】模拟算法——Z字形变换(medium)
【算法】模拟算法——Z字形变换(medium)
|
算法 搜索推荐 Java
【经典算法】LeetCode 215. 数组中的第K个最大元素(Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 215. 数组中的第K个最大元素(Java/C/Python3实现含注释说明,Medium)
317 3
|
存储 算法 Java
【经典算法】LeetCode 5: 最长回文子串(Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 5: 最长回文子串(Java/C/Python3实现含注释说明,Medium)
274 2
|
存储 缓存 算法
【经典算法】LeetCode 1143:最长公共子序列Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 1143:最长公共子序列Java/C/Python3实现含注释说明,Medium)
92 1
|
4天前
|
传感器 机器学习/深度学习 算法
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
|
7天前
|
机器学习/深度学习 算法 调度
基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)
基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)
|
6天前
|
传感器 算法 数据挖掘
基于协方差交叉(CI)的多传感器融合算法matlab仿真,对比单传感器和SCC融合
基于协方差交叉(CI)的多传感器融合算法,通过MATLAB仿真对比单传感器、SCC与CI融合在位置/速度估计误差(RMSE)及等概率椭圆上的性能。采用MATLAB2022A实现,结果表明CI融合在未知相关性下仍具鲁棒性,有效降低估计误差。
|
7天前
|
负载均衡 算法 调度
基于遗传算法的新的异构分布式系统任务调度算法研究(Matlab代码实现)
基于遗传算法的新的异构分布式系统任务调度算法研究(Matlab代码实现)
75 11
|
7天前
|
机器学习/深度学习 传感器 算法
基于全局路径的无人地面车辆的横向避让路径规划研究[蚂蚁算法求解](Matlab代码实现)
基于全局路径的无人地面车辆的横向避让路径规划研究[蚂蚁算法求解](Matlab代码实现)

热门文章

最新文章