国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

LEETCODE--Ransom Note

2019-11-14 13:13:38
字體:
供稿:網(wǎng)友

Given an arbitrary ransom note string and another string containing letters from all the magazines, write a function that will return true if the ransom note can be constructed from the magazines ; otherwise, it will return false. Each letter in the magazine string can only be used once in your ransom note. Note: You may assume that both strings contain only lowercase letters. canConstruct(“a”, “b”) -> false canConstruct(“aa”, “ab”) -> false canConstruct(“aa”, “aab”) -> true 方法一:先排序后再進(jìn)行匹配;

class Solution {public: bool canConstruct(string ransomNote, string magazine) { sort(ransomNote.begin(), ransomNote.end()); sort(magazine.begin(), magazine.end()); int i = 0; int j = 0; while(i < ransomNote.length() && j < magazine.length()){ if(ransomNote[i] == magazine[j]){ cout << ransomNote[i] << endl;; i++; } j++; } if(i == ransomNote.length()) return 1; else return 0; }};

方法二: 使用標(biāo)記數(shù)組A,因?yàn)榭赡艹霈F(xiàn)的字符只有26個(gè)(是有限的)。A中的元素表示magazine中相應(yīng)字符出現(xiàn)的次數(shù).

class Solution {public: bool canConstruct(string ransomNote, string magazine) { int A[26] = {0}; int rlen = ransomNote.length(); int mlen = magazine.length(); for(int i = 0; i < mlen; i++) ++A[magazine[i] - 'a']; for(int j = 0; j < rlen; j++){ if(--A[ransomNote[j] - 'a'] < 0) return 0; } return 1; }};
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 马山县| 贵港市| 密云县| 海盐县| 东兰县| 济源市| 资溪县| 阜南县| 金坛市| 建宁县| 尼勒克县| 海林市| 信宜市| 旌德县| 长丰县| 邵武市| 方正县| 大名县| 顺昌县| 兴业县| 霍邱县| 云和县| 灵川县| 新蔡县| 玉环县| 瑞丽市| 汶川县| 保亭| 赣州市| 拜泉县| 东方市| 南京市| 长乐市| 桐城市| 峨山| 沙田区| 边坝县| 焦作市| 屯昌县| 铜山县| 商丘市|