阿里 LeetCode 1189.“气球“的最大数量

思路:根据题目模拟即可。先统计text中与单词balloon相关的字符数量,由于一个单词需要消耗两个l和o字符,对其统计数量进行除2向下取整,然后所有字符的最小出现次数即是能够凑成balloon的最大数量。

复杂度分析:

1.时间复杂度:假如C为目标字符串的字符种类数量,本题中C = 5,统计text的词频复杂度为O(n),计算答案的复杂度为O(C),因此整体的复杂度为O(n + C)。

2.空间复杂度:O(C)。

附代码:

java 复制代码
class Solution {
    public int maxNumberOfBalloons(String text) {
        int[] cnt = new int[5];
        for(int i = 0;i < text.length();i++){
            char c = text.charAt(i);
            if(c == 'b') cnt[0]++;
            else if(c == 'a') cnt[1]++;
            else if(c == 'l') cnt[2]++;
            else if(c == 'o') cnt[3]++;
            else if(c == 'n') cnt[4]++;
        }
        cnt[2] /= 2;
        cnt[3] /= 2;
        int ans = cnt[0];
        for(int i = 0;i < 5;i++){
            ans = Math.min(ans,cnt[i]);
        }
        return ans;
    }
}

ACM模式:

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String text = scanner.nextLine();
        Solution solution = new Solution();
        int result = solution.maxNumberOfBalloons(text);
        System.out.println(result);
        scanner.close();
    }
}

class Solution {
    public int maxNumberOfBalloons(String text) {
        int[] cnt = new int[5];
        for (int i = 0; i < text.length(); i++) {
            char c = text.charAt(i);
            if (c == 'b') cnt[0]++;
            else if (c == 'a') cnt[1]++;
            else if (c == 'l') cnt[2]++;
            else if (c == 'o') cnt[3]++;
            else if (c == 'n') cnt[4]++;
        }
        cnt[2] /= 2;
        cnt[3] /= 2;
        int ans = cnt[0];
        for (int i = 0; i < 5; i++) {
            ans = Math.min(ans, cnt[i]);
        }
        return ans;
    }
}
相关推荐
JAVA面经实录91714 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
开源Z16 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎16 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
syagain_zsx17 小时前
STL 之 vector 讲练结合
c++·算法
MartinYeung518 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang18 小时前
C++原型模式(Protype)
开发语言·c++·算法
bIo7lyA8v18 小时前
算法复杂度的渐进分析与实际运行时间的差异的技术8
算法
yuan1999719 小时前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab
汉克老师20 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利