首页 > 其他分享 >day14

day14

时间:2022-11-08 20:12:28浏览次数:36  
标签:ransomNote map return int day14 ++ magazine

[0001.两数之和]

  • 不会用 map。。。后面再看 先放着

C++代码:

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        std::unordered_map <int, int> map;
        for(int i = 0; i < nums.size(); i++) {
            // 遍历当前元素,并在map中寻找是否有匹配的key
            auto iter = map.find(target - nums[i]); 
            if(iter != map.end()) {
                return {iter->second, i};
            }
            // 如果没找到匹配对,就把访问过的元素和下标加入到map中
            map.insert(pair<int, int>(nums[i], i)); 
        }
        return {};
    }
};

[0454.四数相加II]

C++代码:

class Solution {
public:
    int fourSumCount(vector<int>& A, vector<int>& B, vector<int>& C, vector<int>& D) {
        unordered_map<int, int> umap; //key:a+b的数值,value:a+b数值出现的次数
        // 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中
        for (int a : A) {
            for (int b : B) {
                umap[a + b]++;
            }
        }
        int count = 0; // 统计a+b+c+d = 0 出现的次数
        // 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,就把map中key对应的value也就是出现次数统计出来。
        for (int c : C) {
            for (int d : D) {
                if (umap.find(0 - (c + d)) != umap.end()) {
                    count += umap[0 - (c + d)];
                }
            }
        }
        return count;
    }
};

  • 没思路 不会用 以后再做

[0383.赎金信]

class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        vector<int> hash (26 , 0);
        for (int i = 0; i < magazine.size(); i++) {
            hash[magazine[i] - 'a']++;
        }
        for (int i = 0; i <  ransomNote.size(); i++) {
            hash[ransomNote[i] - 'a']--;
        }
        for (int i = 0; i <  26; i++) {
            if (hash[i] < 0) {
                return false;
            }
        }
        return true;
    }
};
  • 本来以为得用 map set 想着抄一遍答案 下次再做算了 看到解答思路 说是用数组 并且本题和 有效的字母异位词很像 虽然不能一下反应上来那道题是怎么做得 貌似是 一个数组先去映射成hash表 ++操作 另一个数组在hash表里查找--操作

  • 本题有暴力解法 说实话 里面用到erase函数我还没太理解

  • 本题哈希法采用数组结构 最关键的思想是 ”因为题目所只有小写字母,那可以采用空间换取时间的哈希策略, 用一个长度为26的数组还记录magazine里字母出现的次数。

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

// 时间复杂度: O(n)
// 空间复杂度:O(1)
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        int record[26] = {0};
        //add
        if (ransomNote.size() > magazine.size()) {
            return false;
        }
        for (int i = 0; i < magazine.length(); i++) {
            // 通过recode数据记录 magazine里各个字符出现次数
            record[magazine[i]-'a'] ++;
        }
        for (int j = 0; j < ransomNote.length(); j++) {
            // 遍历ransomNote,在record里对应的字符个数做--操作
            record[ransomNote[j]-'a']--;
            // 如果小于零说明ransomNote里出现的字符,magazine没有
            if(record[ransomNote[j]-'a'] < 0) {
                return false;
            }
        }
        return true;
    }
};
  • 首先 标准答案比我好在最开始的判断语句 如果救赎金比杂志长度大 那么明显就是false
  • 其次 标准答案 把验证--操作 和验证是否<0 操做同时在一个for循环里进行 确实简洁 因为 反正不会再++ 那么只要 一旦<0 就可以返回false 而不需要等到所有--操作完成之后再判断每一个元素值是否小于0

标签:ransomNote,map,return,int,day14,++,magazine
From: https://www.cnblogs.com/deservee/p/16871014.html

相关文章

  • day14
    数组优点:查询/检索某个下标上的元素时效率极高,可以说是查询效率最高的一个数据结构。每个元素的内存地址在空间存储上是连续的。每个元素类型相同,占用的空间大小一样......
  • 代码随想录Day14
    二叉树:满二叉树:除叶子结点,每个节点都满。完全二叉树:叶子节点可以不满,但是一定保证从左到右的顺序存在,中间不能空。  二叉搜索树:有数值,左小右大平衡二叉搜索树:左......
  • Pthon教程Day14-文件操作
    文件操作一、文件操作的作用​​思考​​:什么是文件?​​思考​​:文件操作包含什么?答:打开、关闭、读、写、复制....​​思考​​:文件操作的的作用是什么?答:读取内容、写入内容......
  • day14 正则表达式
    昨天内容回顾cookie为了解决http的无状态问题(使用cookie来保存对应的seesionID位于浏览器上)cookie的特性cookie里面只能存储4kb的数据cookie位于浏览器上cookie......
  • 《剑指offer》day14
    矩阵中的路径题目描述思路深度优先搜索朝一个方向搜索,不行的话就回溯到上一个节点往其他方向搜索代码实现classSolution{publicbooleanexist(char[][]......
  • java_day14
    Java基础Java集合框架泛型本质是参数化类型,把类型作为参数传递常见类型有泛型类、泛型接口、泛型方法好处:提高代码的重用性、防止类型转换异常​ 泛型类/***......
  • 进入python的世界_day14_python基础——算法、三元表达式、生成式、匿名函数
    一、算法1.介绍​ 算法是通过数学模型运算得到某些数据的过程,在python中通过与代码相结合,可以在特定场景下很方便的解决问题2.应用场景​ 很广,大数据推广就是利用算......
  • Python学习路程——Day14
    Python学习路程——Day14算法简介1、什么是算法''' 算法就是解决问题的有效方法,并不是所有的算法都很高效、也不是所有的算法都合格。'''2、算法应用场景''' 推荐......
  • day14学习内容分享
    今日内容概要算法简介及而二分法三元表达式各种生成式匿名函数重要内置函数常见内置函数内容详细算法简介及二分法算法(概念了解)什么是算法算法就是解......
  • 代码随想录day14 | 144.二叉树的前序遍历 94.二叉树的中序遍历 145.二叉树的后续遍历
    144.二叉树的前序遍历题目|文章1.递归思路1.确定参数和返回值2.确定终止条件3.确定单层递归的逻辑实现点击查看代码/***Definitionforabinarytreenode.......