zoukankan      html  css  js  c++  java
  • 383. Ransom Note

    1. 问题描述

    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

    Tags: String

    2. 解题思路


    3. 代码

    class Solution {
    public:
        bool canConstruct(string ransomNote, string magazine)
        {
            std::map<char, int> m1;
            for (int i=0; i<magazine.size(); i++)
            {
                m1[magazine[i]]++;
            }
    
            std::map<char, int> m2;
            for (int i=0; i<ransomNote.size(); i++)
            {
                m2[ransomNote[i]]++;
            }
    
            if (m2.size() > m1.size())
            {
                return false;
            }
    
            map<char, int>::iterator it = m2.begin();
            map<char, int>::iterator itEnd = m2.end();
            for (; it != itEnd; it++)
            {
                if (m1.count(it->first) == 0)
                {
                    return false;
                }
    
                if (it->second > m1[it->first])
                {
                    return false;
                }
            }
            return true;
        }
    };

    4. 反思

  • 相关阅读:
    错误:找不到或无法加载主类
    CentOS 7 命令
    CentOS 7 分区
    Pow(x, n)
    Sum Root to Leaf Numbers
    linux下intel 82579LM 网卡驱动安装
    printf打印字符耗时多少
    数组中移动0至后面
    SDL多线程问题之--Unknown request in queue while dequeuing
    java学习123>>IO
  • 原文地址:https://www.cnblogs.com/whl2012/p/5805052.html
Copyright © 2011-2022 走看看