【LeetCode】383. 赎金信(String的遍历)

  今日学习的文章链接和视频链接

leetcode题目地址:383. 赎金信

 代码随想录题解地址:代码随想录

题目简介

给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false 。

magazine 中的每个字符只能在 ransomNote 中使用一次。

看到题目的第一想法(可以贴代码)

1. 利用Map来存储magazine里的元素及其出现的次数,再用ransomNote里的元素去“消耗它”,若最后次数为 -1 或根本不存在该元素,则return false。

public boolean canConstruct(String ransomNote, String magazine) {
    Map<Character, Integer> m = new HashMap<>();
    char[] c1 = magazine.toCharArray();
    char[] c2 = ransomNote.toCharArray();
    for (char i : c1){
        if (m.containsKey(i)){
            int temp = m.get(i);
            m.replace(i, ++temp);
        }else {
            m.put(i, 1);
        }
    }
    for (char i : c2){
        if (m.containsKey(i)){
            int temp = m.get(i);
            if (temp == 0) return false;
            m.replace(i, --temp);
        }else {
            return false;
        }
    }
    return true;
}

实现过程中遇到哪些困难

看完代码随想录之后的想法

【解题思路】以空间换取时间,用一个长度为26的数组来记录magazine里字母出现的次数。

然后再用ransomNote去验证这个数组是否包含了ransomNote所需要的所有字母。

依然是数组在哈希法中的应用。

【想法】

1. 一些同学可能想,用数组干啥,都用map完事了,其实在本题的情况下,使用map的空间消耗要比数组大一些的,因为map要维护红黑树或者哈希表,而且还要做哈希函数,是费时的!数据量大的话就能体现出来差别了。 所以数组更加简单直接有效!

看完视频自己写的ACC:

public boolean canConstruct(String ransomNote, String magazine) {
    int[] alph = new int[26];
    char[] m = magazine.toCharArray();
    char[] r = ransomNote.toCharArray();
    for (char i : m){
        alph[i-97]++;
    }
    for (char i : r){
        alph[i-97]--;
        if (alph[i-97] < 0) return false;
    }
    return true;
}

学习时长

12:50 ~ 13:05  解题成功

13:05 ~ 13:10  看视频题解、写博客


今日收获

1. String的遍历:

① for循环直接遍历,强制转换成char类型

String str = "asdfghjkl";
        for(int i=0;i<str.length();i++){
        char ch = str.charAt(i);
}

② 转换成char[]遍历        GOOD!

char[] c=s.toCharArray();
for(char cc:c){
  ...//cc直接用了

③ 利用substring()函数

for(int i=0;i<str.length();i++){
  String subStr = str.substring(i, i+1)
}

相关推荐

  1. LeetCode383. 赎金(String)

    2023-12-19 04:56:03       71 阅读
  2. LeetCode383赎金

    2023-12-19 04:56:03       35 阅读
  3. LeetCode 383赎金

    2023-12-19 04:56:03       31 阅读
  4. Leetcode 383. 赎金

    2023-12-19 04:56:03       24 阅读
  5. LeetCode每日一题 | 383. 赎金

    2023-12-19 04:56:03       63 阅读
  6. 383. 赎金

    2023-12-19 04:56:03       63 阅读
  7. 383.赎金

    2023-12-19 04:56:03       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-19 04:56:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-19 04:56:03       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-19 04:56:03       87 阅读
  4. Python语言-面向对象

    2023-12-19 04:56:03       96 阅读

热门阅读

  1. 芯知识 | 什么是音频蓝牙播放语音芯片?

    2023-12-19 04:56:03       70 阅读
  2. 用户行为分析-小数据集

    2023-12-19 04:56:03       73 阅读
  3. vue3组件注册

    2023-12-19 04:56:03       59 阅读
  4. MySQL_11.InnoDB Buffer Pool原理与配置

    2023-12-19 04:56:03       44 阅读
  5. FFmpeg 安装配置

    2023-12-19 04:56:03       45 阅读
  6. 解释区块链技术的应用场景和优势

    2023-12-19 04:56:03       59 阅读
  7. Cmake找不到mysql.h和libmysqlclient.so

    2023-12-19 04:56:03       67 阅读
  8. 如何在Linux命令行下发送和接收UDP数据包

    2023-12-19 04:56:03       64 阅读