【代码随想录37期】Day07四数相加Ⅱ、赎金信、三数之和、四数之和

四数相加Ⅱ

代码随想录

454. 四数相加 II - 力扣(LeetCode)

v1.0:直接超时,完全可以把0 - nums1[i]-nums2[j]作为一组,避免了三重循环!
class Solution {
public:int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {unordered_map<int,int> map;int n = nums1.size();for(int i = 0;i<n;i++){for(int j = 0;j<n; j++){for(int k = 0;k<n;k++){int key = 0 - nums1[i]-nums2[j]-nums3[k];map[key]++;}}}int count = 0;for(int l=0;l<n;l++){if(map.find(nums4[l])!=map.end()){count+=map[nums4[l]];}}return count;}};v2.0:直接改进 nums[i]和nums[j]一组,避免三重循环
class Solution {
public:int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {unordered_map<int,int> map;int n = nums1.size();for(int i = 0;i<n;i++){for(int j = 0;j<n; j++){int key = 0 - nums1[i]-nums2[j];map[key]++;}}int count = 0;for(int k = 0;k<n;k++){for(int l=0;l<n;l++){if(map.find(nums3[k]+nums4[l])!=map.end()){count+=map[nums3[k]+nums4[l]];}}}        return count;}
};v3.0:改用rangefor循环加速
class Solution {
public:int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {unordered_map<int,int> map;for(int i:nums1){for(int j :nums2){int key = 0 - i - j;map[key]++;}}int count = 0;for(int k:nums3){for(int l:nums4){if(map.find(k+l)!=map.end()){count+=map[k+l];}}}        return count;}
};

赎金信

383. 赎金信 - 力扣(LeetCode)

代码随想录

v1.0:直接使用数组来统计字母出现次数,然后减去相应的字母次数即可 初见秒
class Solution {
public:bool canConstruct(string ransomNote, string magazine) {if(ransomNote.size()>magazine.size())return false;int chars[26] = {0};for(char c: magazine){chars[c-'a']++;}for(char c: ransomNote){chars[c-'a']--;if(chars[c-'a']<0){return false;}}return true;}
};

三数之和

15. 三数之和 - 力扣(LeetCode)

代码随想录

v1.0:
这道题只需要返回数值而不是下标,所以可以先对数组进行排序
使用三指针方法:最外层一个for循环,i是最小的值
然后对i进行判断,如果i>0直接返回,不用在找了
再使用两个指针,一个指向i+1,一个指向数组最后,分别是中间值和最大值,
然后固定i的情况下移动left和right指针,和大了就把right变小(左移),小了就把left变大(右移)
最后找到了符合的值后,将结果压入result数组,然后再对left和right可能重复的情况进行排除,例如:
-2,-1,-1,-1,2,2,2,2这种情况
class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {vector<vector<int>> result;sort(nums.begin(), nums.end());//sort默认是从小到大排序for(int i = 0; i < nums.size(); i++){if(nums[i]>0)return result;//如果最小的数已经大于0,那么不可能等于0//这里需要排除重复的三元组而不是重复的元素,所以找的是i是否已经等于过某个数//如果使用nums[i]==nums[i+1],那么会把left=i+1时满足三数和等于0的情况漏掉if(i>0 && nums[i]==nums[i-1]){continue;}int left = i + 1;int right = nums.size()-1;while(left<right){if(nums[i]+nums[left]+nums[right]>0){right--;}else if(nums[i]+nums[right]+nums[left]<0){left++;}else{result.push_back(vector<int>{nums[i], nums[left], nums[right]});while(right>left&&nums[right]==nums[right-1]){right--;}while(right>left&&nums[left]==nums[left+1]){left++;}right--;left++;}} }return result;}
};

四数之和

代码随想录

18. 四数之和 - 力扣(LeetCode)

这道题跟三数之和一个思路,只是外层多一层循环,以此类推五数之和、六数之和都是这样做
但是需要注意的是,这里的target不是固定的,所以剪枝的时候要确定值大于等于0
v1.0:
class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> result;sort(nums.begin(), nums.end());for(int i = 0; i< nums.size();i++){//不要判断nums[k] > target 就返回了,//三数之和 可以通过 nums[i] > 0 就返回了,因为 0 已经是确定的数了//四数之和target是任意值。//比如:数组是[-4, -3, -2, -1],target是-10,不能因为-4 > -10而跳过。if(nums[i]>target&&nums[i]>=0){return result;}if(i>0 && nums[i]==nums[i-1]){continue;}for(int j = i+1; j < nums.size();j++){if(nums[j] + nums[i]>target&&nums[j] + nums[i]>=0){break;//这里不能直接return result,因为外层还有循环!}if(j>i+1 && nums[j]==nums[j-1]){continue;}int left = j + 1;int right = nums.size()-1;while(left<right){if((long)nums[i]+nums[j]+nums[left]+nums[right]>target){right--;}else if((long)nums[i]+nums[j]+nums[left]+nums[right]<target){left++;}else{result.push_back(vector<int>{nums[i], nums[j], nums[left], nums[right]});while(left<right&&nums[left]==nums[left+1]){left++;}while(left<right&&nums[right]==nums[right-1]){right--;}left++;right--;}}}}return result;}
};

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

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

相关文章

收集垃圾的最少总时间- (LeetCode)

题目 给你一个下标从 0 开始的字符串数组 garbage &#xff0c;其中 garbage[i] 表示第 i 个房子的垃圾集合。garbage[i] 只包含字符 M &#xff0c;P 和 G &#xff0c;但可能包含多个相同字符&#xff0c;每个字符分别表示一单位的金属、纸和玻璃。垃圾车收拾 一 单位的任何…

SpringJPA审计

1.实体类 package com.tiger.jpatest.entity;import jakarta.persistence.*; import lombok.Data; import org.springframework.data.annotation.CreatedBy; import org.springframework.data.annotation.CreatedDate; import org.springframework.data.annotation.LastModifi…

图片标签 以及 常见的图片的格式

1.图片的基本使用 2.图片的常见格式 3.bmp格式

前端已死? Bootstrap--JS-jQuery

目录 Bootstrap--JS-jQuery 1 jQuery基础 介绍 基础语法&#xff1a; $(selector).action() 1.1 安装jQuery 地址 基础语法&#xff1a; $(selector).action() 2 jQuery事件 事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。 jQuery常用事件 2.1 鼠标事件…

element-ui的表单中,输入框、级联选择器的长度设置

使用<el-col>控制输入框的长度 <el-form-item label"姓名" label-width"80px"><el-col :span"15"><el-input v-model"form.name" autocomplete"off"></el-input></el-col></el-form…

AI助力内容创作:让效率与质量齐飞

简述&#xff1a; 本文介绍了AI如何帮助创作者在保持内容质量的同时&#xff0c;大幅度提升生产效率的一些方法&#xff0c;希想 对大家有帮助。 一、自动化内容生成 1. 文本内容生成 使用GPT等模型&#xff1a;利用如GPT-3或GPT-4等大型语言模型&#xff0c;可以直接输入关…

linux进阶高级配置,你需要知道的有哪些(12)-rsync

1、rsync的作用 一款快速增量备份工具 支持本地复制&#xff0c;或者与其他SSH、rsync主机同步 2、配置源的两种表示方法&#xff08;服务器端&#xff09; 方法一&#xff1a;用户名主机地址&#xff1a;&#xff1a;共享模块名 方法二&#xff1a;rsync&#xff1a;//用户名…

[译文] 恶意代码分析:2.LNK文件伪装成证书传播RokRAT恶意软件(含无文件攻击)

这是作者新开的一个专栏&#xff0c;主要翻译国外知名安全厂商的技术报告和安全技术&#xff0c;了解它们的前沿技术&#xff0c;学习它们威胁溯源和恶意代码分析的方法&#xff0c;希望对您有所帮助。当然&#xff0c;由于作者英语有限&#xff0c;会借助LLM进行校验和润色&am…

Github项目管理——仓库概述(一)

个人名片&#xff1a; &#x1f393;作者简介&#xff1a;嵌入式领域优质创作者&#x1f310;个人主页&#xff1a;妄北y &#x1f4de;个人QQ&#xff1a;2061314755 &#x1f48c;个人邮箱&#xff1a;[mailto:2061314755qq.com] &#x1f4f1;个人微信&#xff1a;Vir2025WB…

28、查看Qt源码

一、方法1 在安装Qt时&#xff0c;需要勾选“Sources” 在Qt的安装目录Qt5.12.10\5.12.10\Src中可以找到Qt的源码 二、方法2 访问如下网址&#xff08;需要翻墙&#xff09; https://codebrowser.dev/ 在搜索框中输入要查找的信息&#xff0c;如&#xff1a;QMainWindow&…

【IDE】com.intellij.debugger.engine.evaluation.EvaluateException

目录标题 报错重现代码分析解决方式 报错重现 Error during generated code invocation com.intellij.debugger.engine.evaluation.EvaluateException: Method threw java.lang.NullPointerException exception.代码分析 //ls来自上下文 ls.stream().map(m->m.getRewardTy…

Windows11系统配置WSL2网络使它支持LAN访问

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、WSL2安装二、使用步骤1.NAT2.镜像 三、写在最后总结 前言 WSL2的出现感觉真的是一个惊喜&#xff0c;又想玩Linux&#xff0c;又怕日用搞不了的最佳替代方…

深入理解分布式算法

随着互联网和大数据时代的到来&#xff0c;分布式系统已经成为了当今软件开发领域的主流之一。在分布式系统中&#xff0c;如何高效地协调和管理各个节点之间的数据和计算任务成为了一个重要的问题。分布式算法作为解决这一问题的关键技术之一&#xff0c;扮演着至关重要的角色…

前端 JS 经典:原型和原型链

1. 前言 这个前言很重要&#xff0c;要理解原型、原型链&#xff0c;就需要理解前言里面的一些定义。开始&#xff01; 所有对象都是通过 new 一个函数去创建的&#xff0c;而这个函数通常首字母大写&#xff0c;被称为构造函数。我们也可以通过自定义构造函数&#xff0c;去…

Largest Digit(思维题)

The 2023 ICPC Asia Jinan Regional Contest (The 2nd Universal Cup. Stage 17: Jinan) D. Largest Digit 题意&#xff1a; 设 f ( x ) f(x) f(x) 是正整数 x x x 的十进制表示中的最大位数。例如&#xff0c; f ( 4523 ) 5 f(4523) 5 f(4523)5 和 f ( 1001 ) 1 f(1…

深度学习入门到放弃系列 - 阿里云人工智能平台PAI部署开源大模型chatglm3

通过深度学习入门到放弃系列 - 魔搭社区完成开源大模型部署调用 &#xff0c;大概掌握了开源模型的部署调用&#xff0c;但是魔搭社区有一个弊端&#xff0c;关闭实例后数据基本上就丢了&#xff0c;本地的电脑无法满足大模型的配置&#xff0c;就需要去租用一些高性价比的GPU机…

空格探究 空格ASCII码值不一样

背景 今天修改数据库字段发现修改无效,最后发现是空格引起的,数据库中空格有一些奇怪的空格 获取ASCII码,发现不一样 public static void main(String[] args) {String str1 " ";String str2 " ";System.out.println((int)str1.charAt(0) );//13228Syste…

神经网络中的误差反向传播(Backpropagation)方法理解

想象一下&#xff0c;神经网络就像是一个复杂的迷宫&#xff0c;里面有许多交叉路口&#xff08;神经元&#xff09;&#xff0c;每个路口都有指示牌告诉你往哪个方向走&#xff08;权重&#xff09;&#xff0c;而你的目标是找到从入口到出口的最佳路径&#xff0c;使得从起点…

优选算法——双指针2

题目一——有效三角形的个数 思路 先审题 举个例子&#xff0c;下面一个序列可分成4个三元组 然后我们论证哪个可以组成三角形即可 判断三个数能不能组成三角形&#xff1a;任意两边之和大于第三边 注意第一个和第四个&#xff0c;有人说&#xff0c;这不是两个相同的吗&#…

原生小程序开发如何使用 tailwindcss

原生小程序开发如何使用 tailwindcss 原生小程序开发如何使用 tailwindcss 前言什么是 weapp-tailwindcss ?0. 准备环境以及小程序项目1. 安装与配置 tailwindcss 0. 使用包管理器安装 tailwindcss1. 在项目目录下创建 postcss.config.js 并注册 tailwindcss2. 配置 tailwind…