网站做多个镜像/新闻稿营销

网站做多个镜像,新闻稿营销,wordpress应用apok主题,app推广拉新工作可靠吗文章目录 前言有效的三角形个数思路 查找总价格为目标值的两个商品思路 两数之和思路 三数之和思路 四数之和思路 总结 前言 本专栏的上篇,讲述了双指针的一些基础的算法习题 今天我们来学习更进一步的双指针用法吧 其实也是大相径庭,和前面的差不多&…

在这里插入图片描述

文章目录

  • 前言
  • 有效的三角形个数
    • 思路
  • 查找总价格为目标值的两个商品
    • 思路
  • 两数之和
    • 思路
  • 三数之和
    • 思路
  • 四数之和
    • 思路
  • 总结

前言

本专栏的上篇,讲述了双指针的一些基础的算法习题
今天我们来学习更进一步的双指针用法吧
其实也是大相径庭,和前面的差不多,只不过题目难了一些
fellow me

有效的三角形个数

有效的三角形个数
在这里插入图片描述

思路

第一种解法就是——暴力求解(会超时)
三层 for 循环枚举出所有的三元组,并且判断是否能构成三角形。
虽然说是暴力求解,但是还是想优化一下:
判断三角形的优化:
如果能构成三角形,需要满足任意两边之和要大于第三边。但是实际上只需让较小的两条边之和大于第三边即可。
因此我们可以先将原数组排序,然后从小到大枚举三元组,一方面省去枚举的数量另一方面方便判断是否能构成三角形。
第二种解法就是——双指针
根据「解法一」中的优化思想,我们可以固定一个「最长边」,然后在比这条边小的有序数组中找出一个二元组,使这个二元组之和大于这个最长边。由于数组是有序的,我们可以利用**「对撞指针」来优化。
先给数组排序,然后从右边开始
指定一个数**,再在这个数的左边区间定义 left 和 right 指针进行对撞
如果 nums[left] + nums[right] > nums[i]说明 [left, right - 1] 区间上的所有元素均可以与 nums[right] 构成比nums[i] 大的二元组
满足条件的有 right - left
此时 right 位置的元素的所有情况相当于全部考虑完毕, right-- ,进入下一轮判断
如果 nums[left] + nums[right] <= nums[i]
说明 left 位置的元素是不可能与 [left + 1, right] 位置上的元素构成满足条件的二元组
left 位置的元素可以舍去, left++ 进入下轮循环

话不多说上代码吧

class Solution 
{
public:int triangleNumber(vector<int>& nums) {sort(nums.begin(),nums.end());int ret = 0, n = nums.size();for(int i = n - 1; i >= 2; i--){int left = 0, right = i - 1;while(left < right){if(nums[left] + nums[right] > nums[i]){ret += right - left;right--;}else{left++;}}}return ret;}
};

查找总价格为目标值的两个商品

查找总价格为目标值的两个商品
在这里插入图片描述

思路

解法一肯定还是暴力解法,但是超时是不可避免的
就是两层for循环遍历就好啦
解法二我们使用双指针
初始化 left , right 分别指向数组的左右两端(这里不是我们理解的指针,而是数组的下标)
当 left < right 的时候,一直循环
nums[left] + nums[right] == target 时,说明找到结果,记录结果,并且返回
nums[left] + nums[right] < target 时:
对于 nums[left] 而言,此时 nums[right] 相当于是 nums[left] 能碰到的最大值(别忘了,这里是升序数组哈~)。如果此时不符合要求,说明在这个数组里面,没有别的数符合 nums[left] 的要求了(最大的数都满足不了你,你已经没救了)
因此,我们可以大胆舍去这个数,让 left++ ,去比较下一组数据;
那对于 nums[right] 而言,由于此时两数之和是小于目标值的, nums[right]还可以选择比 nums[left] 大的值继续努力达到目标值,因此 right 指针我们按兵不动;
当 nums[left] + nums[right] > target 时,同理我们可以舍去nums[right] (最小的数都满足不了你,你也没救了)。让 right-- ,继续比较下一组数据,而 left 指针不变(因为他还是可以去匹配比 nums[right] 更小的数的)
其实和上一题差不多,相对来说比较简单
话不多说,上代码

class Solution 
{
public:vector<int> twoSum(vector<int>& price, int target) {int left = 0, right = price.size()-1;while(left < right){int sum = price[left] + price[right];if(sum == target)return {price[left],price[right]};else if(sum > target) right--;else left++; }return {-1,-1};}
};

两数之和

两数之和

在这里插入图片描述

思路

其实和上一题差不多的,就是初始化 left 和 right 两个指针
然后对撞找出 numbers[left] + numbers[right] == target 的两个数就好啦
话不多说,上代码

class Solution 
{
public:vector<int> twoSum(vector<int>& numbers, int target) {int left = 0, right = numbers.size() - 1;while(left < right){if(numbers[left] + numbers[right] > target){right--;}else if(numbers[left] + numbers[right] < target){left++;}else{return {left + 1, right + 1};}}return {-1, -1};}
};

三数之和

三数之和
在这里插入图片描述

思路

本题与两数之和类似,与两数之和稍微不同的是,题目中要求找到所有「不重复」的三元组。
那我们可以利用在两数之和(上一题)那里用的双指针思想,来对我们的暴力枚举做优化:
先排序;
然后固定一个数 a :
在这个数后面的区间内,使用「双指针算法」快速找到两个数之和等于 -a 即可。但是要注意的是,这道题里面需要有**「去重」操作**~

找到一个结果之后, left 和 right 指针要「跳过重复」的元素
当使用完一次双指针算法之后,固定的 **a 也要「跳过重复」**的元素。
思路比较简单,但是代码还是有点多

class Solution
{
public:vector<vector<int>> threeSum(vector<int>& nums) {vector<vector<int>> ret;int n = nums.size();sort(nums.begin(),nums.end());for(int i = 0; i < n; ){if(nums[i] > 0) break;int left = i + 1, right = n - 1, target = -nums[i];while(left < right){int sum = nums[left] + nums[right];if(sum > target)right--;else if(sum < target)left++;else{ret.push_back({nums[i], nums[left], nums[right]});left++,right--;while(left < right && nums[left - 1] == nums[left]) left++;//  去重while(left < right && nums[right + 1] == nums[left]) right--; // 去重}}i++;while(i < n && nums[i] == nums[i - 1]) i++;//  去重处理}return ret;}
};

四数之和

四数之和
在这里插入图片描述

思路

和上题差不多的,就是加了一个数而已啦
依次固定一个数 a ;
在这个数 a 的后面区间上,利用「三数之和」找到三个数,使这三个数的和等于 target- a 即可

class Solution 
{
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {int n = nums.size();vector<vector<int>> ret;sort(nums.begin(), nums.end());for(int i = 0; i < n; ){for(int j = i + 1; j < n; ){int left = j + 1, right = n - 1;long long aim = (long long)target - nums[i] - nums[j];while(left < right){int sum = nums[left] + nums[right];if(sum < aim) left++;else if(sum > aim)right--;else{ret.push_back({nums[i], nums[j], nums[left], nums[right]});left++, right--;while(left < right && nums[left - 1] == nums[left]) left++;while(left < right && nums[right + 1] == nums[right]) right--;}}j++;while(j < n && nums[j] == nums[j - 1]) j++;}i++;while(i < n && nums[i] == nums[i - 1])i++;}return ret;}
};

总结

今天对双指针有了新的理解,每一题的练习都是堆知识更加一步的理解
小编将持续不断为大家更新算法题,以及算法知识
一起加油呀~~~~~

在这里插入图片描述

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

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

相关文章

项目实操分享:一个基于 Flask 的音乐生成系统,能够根据用户指定的参数自动生成 MIDI 音乐并转换为音频文件

在线体验音乐创作&#xff1a;AI Music Creator - AI Music Creator 体验者账号密码admin/admin123 系统架构 1.1 核心组件 MusicGenerator 类 负责音乐生成的核心逻辑 包含 MIDI 生成和音频转换功能 管理音乐参数和音轨生成 FluidSynth 集成 用于 MIDI 到音频的转换 …

计算机:基于深度学习的Web应用安全漏洞检测与扫描

目录 前言 课题背景和意义 实现技术思路 一、算法理论基础 1.1 网络爬虫 1.2 漏洞检测 二、 数据集 三、实验及结果分析 3.1 实验环境搭建 3.2 模型训练 最后 前言 &#x1f4c5;大四是整个大学期间最忙碌的时光,一边要忙着备考或实习为毕业后面临的就业升学做准备,…

win32汇编环境,网络编程入门之二

;运行效果 ;win32汇编环境,网络编程入门之二 ;本教程在前一教程的基础上,研究一下如何得到服务器的返回的信息 ;正常的逻辑是连接上了,然后我发送什么,它返回什么,但是这有一个很尴尬的问题。 ;就是如何表现出来。因为网络可能有延迟,这个延迟并不确定有多久。 ;而程序是顺…

【高分论文密码】AI大模型和R语言的全类型科研图形绘制,从画图、标注、改图、美化、组合、排序分解科研绘图每个步骤

在科研成果竞争日益激烈的当下&#xff0c;「一图胜千言」已成为高水平SCI期刊的硬性门槛——数据显示很多情况的拒稿与图表质量直接相关。科研人员普遍面临的工具效率低、设计规范缺失、多维数据呈现难等痛点&#xff0c;因此科研绘图已成为成果撰写中的至关重要的一个环节&am…

大语言模型-1.2-大模型技术基础

简介 本博客内容是《大语言模型》一书的读书笔记&#xff0c;该书是中国人民大学高瓴人工智能学院赵鑫教授团队出品&#xff0c;覆盖大语言模型训练与使用的全流程&#xff0c;从预训练到微调与对齐&#xff0c;从使用技术到评测应用&#xff0c;帮助学员全面掌握大语言模型的…

uni-app打包成H5使用相对路径

网上找了一圈&#xff0c;没用&#xff0c;各种试&#xff0c;终于给试出来了&#xff0c;主要是网络上的没有第二步&#xff0c;只有第一步&#xff0c;导致打包之后请求的路径没有带上域名 运行的基础路径设置为./ config.js文件里面的baseUrl路径改成空字符&#xff0c;千万…

【Linux内核系列】:文件系统

&#x1f525; 本文专栏&#xff1a;Linux &#x1f338;作者主页&#xff1a;努力努力再努力wz ★★★ 本文前置知识&#xff1a; 文件系统初识 那么在我们此前关于文件的学习中&#xff0c;我们学习的都是进程与打开的文件之间的关系&#xff0c;以及打开的文件如何进行管理…

git commit messege 模板设置 (规范化管理git)

配置方法 git config --global core.editor vim &#xff08;设置 Git 的默认编辑器为 Vim&#xff09;在用户根目录下&#xff08;~&#xff09;&#xff0c;创建一个.git_commit_msg文件&#xff0c;然后把下面的内容拷贝到文件中并保存。 [version][模块][类型]{解决xxx问题…

ChatGPT4.5详细介绍和API调用详细教程

OpenAI在2月27日发布GPT-4.5的研究预览版——这是迄今为止OpenAI最强大、最出色的聊天模型。GPT-4.5在扩大预训练和微调规模方面迈出了重要的一步。通过扩大无监督学习的规模&#xff0c;GPT-4.5提升了识别内容中的模式、建立内容关联和生成对于内容的见解的能力&#xff0c;但…

AI 中对内存的庞大需求

刚接触AI时&#xff0c;只知道AI对显存的要求很高&#xff0c;但慢慢发现&#xff0c;AI对内存的要求也越来越高了。 最近尝试玩下 wan 2.1 &#xff0c;进行图生视频&#xff0c;使用comfyui官方工作流&#xff0c;720p&#xff08;720*1280&#xff09;53帧&#xff0c;结果…

如何选择适合您智能家居解决方案的通信协议?

如何选择适合您智能家居解决方案的通信协议&#xff1f; 在开发智能家居产品时&#xff0c;选择合适的通信协议对于设备的高效运行及其在智能家居系统中的互操作性至关重要。市面上协议众多&#xff0c;了解它们的特性并在做决定前考虑各种因素是非常必要的。以下是一些帮助您…

L3-1 夺宝大赛

输入样例 1&#xff1a; 5 7 1 1 1 1 1 0 1 1 1 1 1 1 0 0 1 1 0 2 1 1 1 1 1 0 0 1 1 1 1 1 1 1 1 1 1 7 1 5 7 1 1 1 5 5 3 1 3 5 1 4输出样例 1&#xff1a; 7 6样例 1 说明&#xff1a; 七支队伍到达大本营的时间顺次为&#xff1a;7、不可能、5、3、3、5、6&#xff0c…

海思高安主控芯片兼容编译fastboot流程

华为海思主控芯片有高安和非高安之分&#xff0c;主要是安全性上区别&#xff0c;启动程序不同&#xff0c;一般无法共用。但实际生产中可能出现混料或者同一款产品不同批次一个是高安的一个是非高安的&#xff0c;这时就需要软件上做兼容&#xff0c;实际是高安固件是可以做到…

C# WPF 基础知识学习(二)

四、数据绑定 &#xff08;一&#xff09;数据绑定基础 绑定源和目标&#xff1a;数据绑定建立了 UI 元素&#xff08;绑定目标&#xff09;属性与数据源&#xff08;绑定源&#xff09;之间的联系。例如&#xff0c;将一个TextBox的Text属性绑定到一个对象的某个属性上。绑定…

Trae AI IDEA安装与使用

文章目录 背景第一步、下载安装第二步、登录与使用优势异常处理 背景 最近比较热的 Trae 开发工具&#xff0c;在本地下载使用&#xff0c;记录下来。 第一步、下载安装 下载地址&#xff1a;【Trae中文版下载地址】&#xff0c;下载的安装文件名为&#xff1a;【Trae CN-Se…

【LangChain接入阿里云百炼deepseek】

这是目录 前言阿里云百炼注册账号使用代码执行结果 前言 大模型爆火&#xff0c;现在很多教程在教怎么使用大模型来训练Agent智能体&#xff0c;但是大部分教程都是使用的OpenAI。 最近阿里云推出DeepSeek-R1满血版&#xff0c;新用户可享100万免费Token额度。 今天就教大家怎…

火绒企业版V2.0全面支持Linux与国产化系统!免费试用助力国产化终端安全升级

国产化浪潮下的安全新挑战 随着信创产业的加速推进&#xff0c;国产操作系统&#xff08;统信UOS、麒麟OS等&#xff09;和ARM架构服务器逐步成为政企核心业务的基础设施。然而&#xff0c;针对国产化系统的勒索攻击、网页篡改、供应链漏洞等威胁频发&#xff0c;传统安全方案…

【HarmonyOS Next】鸿蒙加固方案调研和分析

【HarmonyOS Next】鸿蒙加固方案调研和分析 一、前言 根据鸿蒙应用的上架流程&#xff0c;本地构建app文件后&#xff0c;上架到AGC平台&#xff0c;平台会进行解析。根据鸿蒙系统的特殊设置&#xff0c;仿照IOS的生态闭环方案。只能从AGC应用市场下载app进行安装。这样的流程…

win11编译llama_cpp_python cuda128 RTX30/40/50版本

Geforce 50xx系显卡最低支持cuda128&#xff0c;llama_cpp_python官方源只有cpu版本&#xff0c;没有cuda版本&#xff0c;所以自己基于0.3.5版本源码编译一个RTX 30xx/40xx/50xx版本。 1. 前置条件 1. 访问https://developer.download.nvidia.cn/compute/cuda/12.8.0/local_…

【物联网-WIFI】

物联网-WIFI ■ ESP32-C3-模块简介■ ESP32-C3-■ ESP32-C3-■ WIFI-模组■ WIFI-■ WIFI- ■ ESP32-C3-模块简介 ■ ESP32-C3- ■ ESP32-C3- ■ WIFI-模组 ■ WIFI- ■ WIFI-