【算法】模拟算法——数青蛙(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

相关文章
|
1月前
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
1月前
|
算法
【算法】模拟算法——Z字形变换(medium)
【算法】模拟算法——Z字形变换(medium)
|
3月前
|
算法 搜索推荐 Java
【经典算法】LeetCode 215. 数组中的第K个最大元素(Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 215. 数组中的第K个最大元素(Java/C/Python3实现含注释说明,Medium)
28 3
|
3月前
|
存储 算法 Java
【经典算法】LeetCode 5: 最长回文子串(Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 5: 最长回文子串(Java/C/Python3实现含注释说明,Medium)
33 2
|
3月前
|
存储 缓存 算法
【经典算法】LeetCode 1143:最长公共子序列Java/C/Python3实现含注释说明,Medium)
【经典算法】LeetCode 1143:最长公共子序列Java/C/Python3实现含注释说明,Medium)
17 1
|
23天前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
|
23天前
|
算法 数据可视化
基于SSA奇异谱分析算法的时间序列趋势线提取matlab仿真
奇异谱分析(SSA)是一种基于奇异值分解(SVD)和轨迹矩阵的非线性、非参数时间序列分析方法,适用于提取趋势、周期性和噪声成分。本项目使用MATLAB 2022a版本实现从强干扰序列中提取趋势线,并通过可视化展示了原时间序列与提取的趋势分量。代码实现了滑动窗口下的奇异值分解和分组重构,适用于非线性和非平稳时间序列分析。此方法在气候变化、金融市场和生物医学信号处理等领域有广泛应用。
|
24天前
|
资源调度 算法
基于迭代扩展卡尔曼滤波算法的倒立摆控制系统matlab仿真
本课题研究基于迭代扩展卡尔曼滤波算法的倒立摆控制系统,并对比UKF、EKF、迭代UKF和迭代EKF的控制效果。倒立摆作为典型的非线性系统,适用于评估不同滤波方法的性能。UKF采用无迹变换逼近非线性函数,避免了EKF中的截断误差;EKF则通过泰勒级数展开近似非线性函数;迭代EKF和迭代UKF通过多次迭代提高状态估计精度。系统使用MATLAB 2022a进行仿真和分析,结果显示UKF和迭代UKF在非线性强的系统中表现更佳,但计算复杂度较高;EKF和迭代EKF则更适合维数较高或计算受限的场景。
|
25天前
|
算法
基于SIR模型的疫情发展趋势预测算法matlab仿真
该程序基于SIR模型预测疫情发展趋势,通过MATLAB 2022a版实现病例增长拟合分析,比较疫情防控力度。使用SIR微分方程模型拟合疫情发展过程,优化参数并求解微分方程组以预测易感者(S)、感染者(I)和移除者(R)的数量变化。![]该模型将总人群分为S、I、R三部分,通过解析或数值求解微分方程组预测疫情趋势。
|
25天前
|
算法 数据可视化 数据安全/隐私保护
基于LK光流提取算法的图像序列晃动程度计算matlab仿真
该算法基于Lucas-Kanade光流方法,用于计算图像序列的晃动程度。通过计算相邻帧间的光流场并定义晃动程度指标(如RMS),可量化图像晃动。此版本适用于Matlab 2022a,提供详细中文注释与操作视频。完整代码无水印。