【LeetCode】383. 赎金信

题目:383. 赎金信

由于此题只含有小写字母,并且magazine里面的字母不可重复使用.

故首先用一个长度为26的整形数组记录magazine里字母出现的次数。

再用这个整形数组跟ransomeNote进行遍历比较,当数组中出现-1时,说明false,否则true.

代码:

java 复制代码
class Solution {
    public boolean canConstruct(String ransomNote, String magazine) {
        int[] tmp = new int[26];
        
        //遍历magazine中的字符
        for(int i=0;i<magazine.length();i++){
            char ch = magazine.charAt(i);
            tmp[ch-'a']++;
        }

        //遍历ransomNote中的字符
        for(int i=0;i<ransomNote.length();i++){
            char ch = ransomNote.charAt(i);
            tmp[ch-'a']--;
            if(tmp[ch-'a']<0){
                return false;
            }
        }

        return true;
    }
}

运行结果:

相关推荐
abant22 分钟前
leetcode 23合并k个有序链表
算法·leetcode·链表
啊董dong2 分钟前
noi-2026年3月24号作业
数据结构·c++·算法
WolfGang00732116 分钟前
代码随想录算法训练营 Day19 | 回溯算法 part01
数据结构·算法
汉克老师16 分钟前
GESP5级C++考试语法知识(十、二分算法(二))
c++·算法·二分算法·gesp5级·gesp五级·找答案
cheems952730 分钟前
[数据结构]栈和队列的互相模拟实现
数据结构·算法
计算机安禾33 分钟前
【数据结构与算法】第6篇:线性表(二):单链表的实现(头插法、尾插法)
c语言·数据结构·学习·算法·链表·visual studio code·visual studio
2401_8732046533 分钟前
C++与Node.js集成
开发语言·c++·算法
☆56639 分钟前
基于C++的区块链实现
开发语言·c++·算法
ysa0510301 小时前
迷宫传送[最短路径]
c++·笔记·算法·深度优先
计算机安禾1 小时前
【数据结构与算法】第5篇:线性表(一):顺序表(ArrayList)的实现与应用
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio