LeetCode_Day6 | 四数相加||、赎金信、三数之和、四数之和!

news2025/1/11 16:45:28

LeetCode_哈希表

  • 454.四数相加
    • 1.题目描述
    • 2.思路
    • 3.代码实现
  • 383.赎金信
    • 1.题目描述
    • 2.暴力法
    • 3.哈希法
      • 思路
      • 代码实现
  • 15.三数之和
    • 1.题目描述

454.四数相加

1.题目描述

在这里插入图片描述
详情leetcode链接

2.思路

解题步骤:

  • 首先定义 map,key放a和b两数之和,value 放a和b两数之和出现的次数。
  • 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中。
  • 定义int变量count,用来统计 a+b+c+d = 0 出现的次数。
  • 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,就用count把map中key对应的value也就是出现次数统计出来。
  • 最后返回统计值 count 就可以了

3.代码实现

class Solution {
    /**
     * 哈希表法:
     * 首先定义一个map,key放a和b两数之和,value 放a和b两数之和出现的次数。
     * 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中。
     * 定义int变量count,用来统计 a+b+c+d = 0 出现的次数。
     * 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,
     *   就用count把map中key对应的value也就是出现次数统计出来。
     * 最后返回统计值 count 就可以了
     * 时间复杂度:O(n^2)
     * 空间复杂度: O(n^2),最坏情况下A和B的值各不相同,相加产生的数字个数为 n^2
     */
    public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {
        int result = 0;
        Map<Integer, Integer> map = new HashMap<>();
        //统计两个数组中的元素之和,同时统计出现的次数,放入map
        for (int num1: nums1) {
            for (int num2: nums2) {
                int sum = num1+num2;
                map.put(sum, map.getOrDefault(sum, 0)+1);
            }
        }
        //统计剩余的两个元素的和,在map中找是否存在相加为0的情况,同时记录次数
        for (int num3 : nums3){
            for (int num4 : nums4){
                result += map.getOrDefault(0-num3-num4, 0);
            }
        }
        return result;
    }
}

383.赎金信

1.题目描述

在这里插入图片描述
在这里插入图片描述
详情leetcode链接

2.暴力法

两层for循环,不断去寻找,看magazine中的字符串是否能组成ransomNote (时间复杂度较高,不推荐此方法)

class Solution {
    /**
     * 暴力法(不推荐)
     * 两层for循环,不断去寻找,看magazine中的字符串是否能组成ransomNote 
     * 时间复杂度:O(n^2)
     * 空间复杂度:O(1)
     */
    public boolean canConstruct(String ransomNote, String magazine) {
        for (int i = 0; i < magazine.length(); i++){
            for (int j = 0; j < ransomNote.length(); j++) {
                if (magazine.charAt(i)==ransomNote.charAt(j)) {
                    ransomNote = ransomNote.substring(0, j)+ransomNote.substring(j+1);
                    break;
                }
            }
        }

        if (ransomNote.length()==0){
            return true;
        }
        return false;
    }
}

3.哈希法

思路

  • 因为题目所只有小写字母,那可以采用空间换取时间的哈希策略, 用一个长度为26的数组还记录magazine里字母出现的次数。
  • 然后再用ransomNote去验证这个数组是否包含了ransomNote所需要的所有字母。

解释用数组而不用map:
在本题的情况下,使用map的空间消耗要比数组大一些的,因为map要维护红黑树或者哈希表,而且还要做哈希函数,是费时的!数据量大的话就能体现出来差别了。 所以数组更加简单直接有效!

代码实现

class Solution {
    /**
     * 哈希法(推荐)
     * 思路:
     * 因为题目所只有小写字母,那可以采用空间换取时间的哈希策略, 用一个长度为26的数组还记录magazine里字母出现的次数。
     * 然后再用ransomNote去验证这个数组是否包含了ransomNote所需要的所有字母。
     * 解释用数组而不用map:
     * 在本题的情况下,使用map的空间消耗要比数组大一些的,因为map要维护红黑树或者哈希表,而且还要做哈希函数,是费时的!数据量大的话就能体现出来差别了。 所以数组更加简单直接有效!
     * 时间复杂度:O(m + n)O(m+n),其中 mm 是字符串 \textit{ransomNote}ransomNote 的长度,nn 是字符串 \textit{magazine}magazine 的长度,我们只需要遍历两个字符一次即可。
     * 空间复杂度:O(|S|)O(∣S∣),SS 是字符集,这道题中 SS 为全部小写英语字母,因此 |S| = 26∣S∣=26。
     */
    public boolean canConstruct(String ransomNote, String magazine) {
      if (ransomNote.length() > magazine.length()) {
            return false;
        }
        // 定义一个哈希映射数组
        int[] result = new int[26];

        //遍历magazine利用其与小写字母的ASC||相对值映射到数组中
        for (char mag : magazine.toCharArray()){
            result[mag - 'a']+=1;
        }
        //遍历ransomNote利用其与小写字母的ASC||相对值映射到数组中(与上边相反)
        for (char ran : ransomNote.toCharArray()) {
            result[ran - 'a']-=1;
            // 如果数组中存在负数,说明ransomNote字符串总存在magazine中没有的字符
            if (result[ran - 'a']<0){
                return false;
            }
        }
        return true;
    }
}

15.三数之和

1.题目描述

在这里插入图片描述
在这里插入图片描述
详情leetcode链接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/644083.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

神器CLIP:连接文本和图像,打造可迁移的视觉模型

2021年见证了vision transformer的大爆发&#xff0c;随着谷歌提出ViT之后&#xff0c;一大批的vision transformer的工作席卷计算机视觉任务。除了vision transformer&#xff0c;另外一个对计算机视觉影响比较大的工作就是Open AI在2021年1月份发布的DALL-E和CLIP&#xff0c…

chatgpt赋能python:一、Python在数据可视化中的应用

一、Python在数据可视化中的应用 Python是一种功能强大的编程语言&#xff0c;早已成为数据科学家和分析师的首选语言。数据可视化对于从数据中汲取信息和传达想法来说至关重要。Python也是数据可视化的理想工具之一。Python提供了许多强大的库&#xff0c;其中包括了一些流行…

( 2023版)互联网 Java 工程师面试题及答案汇总

最近很多粉丝朋友私信我说&#xff1a;熬过了去年的寒冬却没熬过现在的内卷&#xff1b;打开 Boss 直拒一排已读不回&#xff0c;回的基本都是外包&#xff0c;薪资还给的不高&#xff0c;对技术水平要求也远超从前&#xff1b;感觉 Java 一个初中级岗位有上千人同时竞争&#…

【野指针】

野指针 1. 指针是什么&#xff1f;2. 指针和指针类型2.1 指针-整数2.2 指针的解引用 3. 野指针3.1 野指针成因3.2 如何规避野指针 1. 指针是什么&#xff1f; 指针是什么&#xff1f; 指针理解的2个要点&#xff1a; 指针是内存中一个最小单元的编号&#xff0c;也就是地址平…

MySQL性能优化:慢查询优化

一、执行计划 执行计划的语法 在SQL查询的前面加上EXPLAIN关键字就行。比如: EXPLAIN select* from order_exp;执行效果如下。 &#xff08;一&#xff09;参数详解&#xff1a; 1、id 在一个大的查询语句中每个SELECT关键字都对应一个唯一的id。我们知道我们写的查询语句一…

【框架源码】Spring源码解析之BeanDefinition加载流程解析

观看本文之前&#xff0c;我们先思考一个问题&#xff0c;Spring是如何描述Bean对象的&#xff1f; Spring是根据BeanDefinition来创建Bean对象&#xff0c;BeanDefinition就是Spring中表示Bean定义。BeanDefinition用来存储Bean的相关信息&#xff0c;主要包括&#xff1a;Be…

【Linux问题】删除用户时错把rm当成userdel删除后,该如何解决彻底删除?

问题引入&#xff1a;之前创建的用户默认在home目录中&#xff0c;过了段时间以为是一个目录就直接使用rm删除了&#xff0c;结果在创建一个和之前用户同名的用户时发现报错&#xff1a;useradd: user ‘cjs’ already exists&#xff08;该用户已存在&#xff09;。 1、问题 …

chatgpt赋能python:Python怎么找出最大数的位置?

Python怎么找出最大数的位置&#xff1f; Python是一种高级编程语言&#xff0c;它的简单易学和适用范围广泛使其成为了很多开发者的首选语言。在Python中&#xff0c;有许多方便的内置函数可以帮助我们轻松地处理各种任务。其中之一是查找最大值&#xff0c;但是我们如何找出…

【Linux后端服务器开发】shell脚本

目录 一、变量 1. 普通变量 2. 环境变量 3. 位置变量 4. 特殊变量 二、输入输出 1. read命令接收输入 2. echo命令输出字符串 三、表达式 1. 算术表达式 2. 逻辑表达式 四、分支控制 1. if 分支 2. case 分支 五、循环控制 1. for 循环 2. while 循环 3. unt…

redis键值对映射关系存储-Dict

基本概述 Redis是一个键值型&#xff08;Key-Value Pair&#xff09;的数据库&#xff0c;可以根据键实现快速的增删改查。而键与值的映射关系正是通过Dict来实现的。 Dict由三部分组成&#xff0c;分别是&#xff1a;哈希表&#xff08;DictHashTable&#xff09;、哈希节点&a…

基于51单片机设计的电动车控制器

一、项目介绍 随着社会经济的快速发展,人们对节能环保的要求越来越高,电动车因其无污染、噪音小、使用成本低等优点逐渐成为了市场关注的焦点。同时,随着科技的不断进步和应用,电动车的技术水平也在不断提高。 为了更好地满足市场需求和科技进步的要求,本项目基于51单片…

车载以太网 - 数据链路层 - VLAN

数据链路层通信 以太网二层数据链路层的寻址方式、帧结构、及 VLAN (Virtual LocalArea Network)&#xff0c;其分为LLC(Logical Link Control)逻辑链路控制子层&#xff0c;和 MAC(Media Access Control)媒体访问控制子层&#xff0c;其中&#xff0c;MAC 子层负责以太网的总…

chatgpt赋能python:Python中的异常处理

Python中的异常处理 在Python编程中&#xff0c;异常是指程序出现了不正常的情况&#xff0c;比如语法错误、运行时错误等等。这些异常会导致程序崩溃&#xff0c;所以我们需要在程序中使用异常处理来避免这种情况的发生。 什么是异常处理&#xff1f; 异常处理是一种技术&a…

chatgpt赋能python:Python如何把多行合并成一行

Python如何把多行合并成一行 如果你常常需要处理文本数据&#xff0c;你就会遇到将多行文本合并成一行的需求。在Python中&#xff0c;这个任务非常简单&#xff0c;本文将介绍如何使用Python实现把多行合并成一行。 什么是多行文本&#xff1f; 在编程和文本处理中&#xf…

【MySQL高级篇笔记-其他数据库日志(下) 】

此笔记为尚硅谷MySQL高级篇部分内容 目录 一、MySQL支持的日志 1、日志类型 2、日志的弊端 二、慢查询日志(slow query log) 三、通用查询日志(general query log) 1、问题场景 2、查看当前状态 3、启动日志 方式 1 &#xff1a;永久性方式 方式2&#xff1a;临时性…

回归预测 | MATLAB实现基于LSTM-AdaBoost长短期记忆网络结合AdaBoost多输入单输出回归预测

回归预测 | MATLAB实现基于LSTM-AdaBoost长短期记忆网络结合AdaBoost多输入单输出回归预测 目录 回归预测 | MATLAB实现基于LSTM-AdaBoost长短期记忆网络结合AdaBoost多输入单输出回归预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现基于LSTM-Ad…

chatgpt赋能python:Python如何将多个图像合并输出?

Python如何将多个图像合并输出&#xff1f; 如果您需要将多个图像合并为一个&#xff0c;并将其输出到一个文件中&#xff0c;则Python提供了一些简单的解决方案。在本文中&#xff0c;我们将介绍如何使用Python进行该操作&#xff0c;并附上示例和用法说明。 PIL库 Python …

计算机图形学与opengl C++版 学习笔记 第11章 参数曲面

目录 11.1 二次贝塞尔曲线(三点)11.2 三次贝塞尔曲线(四点)11.3 二次贝塞尔曲面(3x3控制点)11.4 三次贝塞尔曲面(4x4控制点)补充说明 在20世纪50年代和60年代在雷诺公司工作期间&#xff0c;皮埃尔贝塞尔&#xff08;Pierre Bzier&#xff09;开发了用于设计汽车车身的软件系统…

【信息与内容安全复习】第二章知识要点总结

1.网络媒体信息的获取流程 2.三原色原理 3.颜色特征表达的特点、问题和主要方法 4.文本特征表达的方式 5.网络媒体信息与网络通讯信息 6.网络媒体信息获取方法 7.补充 8.视觉特征表达的应用 9.颜色特征表达举例之颜色直方图 10.纹理特征和局部特征 答&#xff1a; 1.网络媒体…

Redis从入门到精通【高阶篇】之底层数据结构字典(Dictionary)详解

文章目录 0.前言1. 字典的结构2. 源码解析2.1. 字典的结构体2.2. 字典的函数接口dictAdddictFinddictResize 3. 字典/哈希表的优缺点3.1 优点3.1.1. 快速的查找时间3.1.2. 动态调整大小3.1.3. 灵活的数据类型3.2 缺点 4.总结5. Redis从入门到精通系列文章 0.前言 上个篇章回顾…