亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

LeetCode贖金信、雜志問題

標簽:
Java

    给定一个赎金信 (ransom) 字符串和一个杂志(magazine)字符串,判断第一个字符串ransom能不能由第二个字符串magazines里面的字符构成。如果可以构成,返回 true ;否则返回 false。

(题目说明:为了不暴露赎金信字迹,要从杂志上搜索各个需要的字母,组成单词来表达意思。)

注意:

你可以假设两个字符串均只含有小写字母。

canConstruct("a", "b") -> false
canConstruct("aa", "ab") -> false
canConstruct("aa", "aab") -> true
分析:
利用HashMap这个集合,new的时候使用两个泛型,key为字符型(Character),value为整数型(Integer),通过存储magazine中的字母和出现的次数,和ransom中的字符进行比较,如果没有则直接返回false,否则减value值。

class Solution {    public boolean canConstruct(String ransomNote, String magazine) {        char[] c = ransomNote.toCharArray();        char[] c1 = magazine.toCharArray();        HashMap<Character,Integer> hm = new HashMap<>();        for(Character character : c1) {            if(!hm.containsKey(character)) {                hm.put(character, 1);            }else {                hm.put(character, hm.get(character)+1);            }        }        for(Character character : c) {            if(!(hm.containsKey(character))){                return false;            }else {                if((hm.get(character) -1) < 0) {                    return false;                }                hm.put(character, hm.get(character)-1);            }        }        return true;    }}

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消