算法练习:双指针

目录

  • 1. 双指针
    • 1.1 移动 "0"
    • 1.2 复写 "0"
    • 1.3 快乐数(快慢指针)
    • 1.4 盛水最多的容器(单调性原则)
    • 1.5 有效三角形个数
    • 1.6 两个数之和
    • 1.7 三数之和
    • 1.8 四数之和

1. 双指针

1.1 移动 “0”

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    移动 “0”

思路演示:
在这里插入图片描述

补充:

  1. [0, dest]区间内的元素都为0
  2. [dest + 1, cur]区间内的元素都不为0
  3. cur指针遍历完数据,调整结束
class Solution 
{
public:void moveZeroes(vector<int>& nums) {int dest = -1;int cur = 0;while(cur < nums.size()){if(nums[cur]){swap(nums[cur], nums[++dest]);}cur++;}}
};

1.2 复写 “0”

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    复写"0"

思路演示:
在这里插入图片描述
在这里插入图片描述

注意:

  1. 寻找最后未覆盖结点时可能回导致dest越界,从而导致逆向复写的过程中出现越界错误。
    例:[0, 0, 0]
    因此,需要对此种越界情况做特殊处理。
class Solution 
{
public:void duplicateZeros(vector<int>& arr) {//找结点int cur = -1;int dest = -1;int size = arr.size();while (dest < size - 1){cur++;if (arr[cur] == 0){dest += 2;}else{dest++;}}//越界可能while(cur >= 0){if(arr[cur] == 0){//特殊处理if(dest > size - 1){arr[--dest] = arr[cur];}else{arr[dest] = arr[cur];arr[--dest] = arr[cur];}}else{//特殊处理if(dest > size - 1){arr[--dest] = arr[cur];}else{arr[dest] = arr[cur];}}dest--;cur--;}}
};

1.3 快乐数(快慢指针)

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    快乐数

过程演示:
在这里插入图片描述

注: 无论数n是否为快乐数,其进行快乐数的判断逻辑一定都会进入一个循环。我们将每次运算得出的结果视为结点,平方和的运算步骤视为链表的一步。那么,上述问题就可以理解为链表循环问题。(是否为只有1的环)

class Solution 
{
public:int gethappy(int num){int sum = 0;while(num){sum += (num % 10) * (num % 10);num /= 10;}return sum;}bool isHappy(int n) {//环状链表,快慢指针int quick = n;int slow = n;do{//快慢指针//走一步slow = gethappy(slow);//走两步quick = gethappy(quick);quick = gethappy(quick);}while(slow != quick);if(slow == 1){return true;}return false;}
};

1.4 盛水最多的容器(单调性原则)

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    盛水最多的容器

过程演示:

思路1:求出所有的容积,然后在其中选出最大(暴力求解)

思路2:单调性原则

在这里插入图片描述

  1. 容器的的高是由短边决定的
  2. 因此可以确定在高不变的情况下,移动长边只会导致底变短
  3. 所以可以确定当前的搭配是以短边为高一组中,容积最大的

只需记录每组中最大的容积,算法时间复杂度优化为O(n)

class Solution {
public:int maxArea(vector<int>& height) {//单调性原则//将小边丢掉int left = 0;int right = height.size() - 1;vector<int> area;while(left < right){if(height[left] < height[right]){area.push_back((right - left) * height[left]);left++;}else{area.push_back((right - left) * height[right]);right--;}}int max = area[0];for(auto e : area){if(e > max){max = e;}}return max;}
};

1.5 有效三角形个数

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    有效三角形个数
  3. 思路:
    <1> 先将所给数组进行排序(升序)
    <2> 判断三个数是否能够组成三角形的三个边:任意两边之和大于第三边
    <3> 指针对撞法(优化暴力求解)

过程演示:
在这里插入图片描述

class Solution 
{
public:int triangleNumber(vector<int>& nums) {//任意两边之和大于第三边//优化先排序再判断sort(nums.begin(), nums.end());int times = 0;int count = nums.size() - 1;int left = 0;int right = count - 1; while(count >= 2){while(right >= 1){while(left < right && nums[right] + nums[left] <= nums[count]){left++;}if(left < right){times += (right - left);}right--;}left = 0;count--;right = count - 1;}return times;}
};

1.6 两个数之和

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    两数之和
  3. 思路:
    <1> 若两数之和大于等于指定数,移动右指针
    <2> 若两数之和小于指定数,移动左指针
    直至两指针相撞

过程演示:
在这里插入图片描述

class Solution 
{
public:vector<int> twoSum(vector<int>& price, int target) {vector<int> goods;//大挪右,小挪左int left = 0;int right =price.size() - 1;while(left < right && price[left] + price[right] != target){if(price[left] + price[right] > target){right--;}if(price[left] + price[right] < target){left++;}}if(left < right){goods.push_back(price[left]);goods.push_back(price[right]);}return goods;}
};

1.7 三数之和

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    三数之和
  3. 思路:
    <1> 将整个数组排序,固定一个数num,创建两个指针left(最左则)与right(固定数num的前一个元素)
    <2> 左右指针开始遍历数组,arr[left] + arr[right] < num,left指针右移,arr[left] + arr[right] > num,right指针左移,当arr[left] + arr[right] > num时,记录此次搭配。重复遍历步骤,直至left >= right,结束此次遍历
    <3> 重复步骤2,直至num < 2

过程演示:
在这里插入图片描述

class Solution 
{
public:vector<vector<int>> threeSum(vector<int>& nums){//排序//去重//单调性vector<vector<int>> v1;sort(nums.begin(), nums.begin() + nums.size());int cur = nums.size() - 1;int right = 0;int left = 0;while (cur > 1){right = cur - 1;left = 0;//一次遍历while (right > left){//判断同时去重if ((right < cur - 1 && nums[right] == nums[right + 1]) || nums[right] + nums[left] > -nums[cur]){right--;}else if ((left > 0 && nums[left] == nums[left - 1]) || nums[right] + nums[left] < -nums[cur]){left++;}else{//记录vector<int> v2;v2.push_back(nums[left]);v2.push_back(nums[right]);v2.push_back(nums[cur]);v1.push_back(v2);right--;}}//去重do{cur--;} while (cur > 1 && nums[cur] == nums[cur + 1]);}return v1;}
};

1.8 四数之和

  1. 题目信息:
    在这里插入图片描述
  2. 题目链接:
    四数之和
  3. 思路:在三指针的基础上再套一层
  4. 注:int类型存在数据溢出的风险
class Solution
{
public:vector<vector<int>> fourSum(vector<int>& nums, int target){sort(nums.begin(), nums.end());vector<vector<int>> vv;int end = nums.size() - 1;int a = 0;while (end - a + 1 >= 4){int b = a + 1;while (end - b + 1 >= 3){int left = b + 1;int right = end;while (left < right){int sum = nums[left] + nums[right];long long goal = (long long)target - nums[a] - nums[b];//去重if ((right < end && nums[right + 1] == nums[right]) || sum > goal){right--;}else if ((left > b + 1 && nums[left - 1] == nums[left]) || sum < goal){left++;}else{vector<int> v;v.push_back(nums[a]);v.push_back(nums[b]);v.push_back(nums[left]);v.push_back(nums[right]);vv.push_back(v);left++;}}do{b++;} while (end - b + 1 >= 3 && nums[b - 1] == nums[b]);}do{a++;} while (end - a + 1 >= 4 && nums[a - 1] == nums[a]);}return vv;}
};

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

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

相关文章

1.4 简述“分组卷积”及其应用场景

1.4 简述“分组卷积”及其应用场景 普通卷积&#xff1a;在普通的卷积操作中&#xff0c;一个卷积核对应输出特征图的一个通道&#xff0c;而每个卷积核又会作用在输入特征图的所有通道上(即卷积核的通道数等于输入特征图的通道数)&#xff0c;因此最终输出特征图的每个通道都…

算法简单试题

一、选择题 01.一个算法应该是( B ). A.程序 B.问题求解步骤的描述 C.要满足五个基本特性 D.A和C 02&#xff0e;某算法的时间复杂度为O(n)&#xff0c;则表示该…

【C++实战项目】Date日期类 --- 运算符重载的深入探索

&#x1f4f7; 江池俊&#xff1a;个人主页 &#x1f525; 个人专栏&#xff1a;✅C那些事儿 ✅Linux技术宝典 &#x1f305; 此去关山万里&#xff0c;定不负云起之望 文章目录 引言一、为什么需要运算符重载&#xff1f;二、日期类的实现1. 基本框架2. 预备工作3. Date 类…

JimuReport积木报表 v1.7.1 版本发布,低代码报表工具

项目介绍 一款免费的数据可视化报表&#xff0c;含报表和大屏设计&#xff0c;像搭建积木一样在线设计报表&#xff01;功能涵盖&#xff0c;数据报表、打印设计、图表报表、大屏设计等&#xff01; Web 版报表设计器&#xff0c;类似于excel操作风格&#xff0c;通过拖拽完成报…

2024年冲刺年薪40w,Android岗面试

一个程序员&#xff0c;如果不想35 岁被淘汰&#xff0c;请把它当成一种信仰&#xff01; 25岁&#xff0c;一个北漂程序员&#xff0c;入职三年&#xff0c;Android中级工程师&#xff0c;月薪15k&#xff0c;965的工作经常干成996&#xff0c;比起老家的同龄人&#xff0c;我…

掘根宝典之C语言文件操作(fgetc,fputc,fscanf,fprintf,fread,fwrite,feek,ftell,fwind,feof)

1. 为什么使⽤⽂件&#xff1f; 如果没有⽂件&#xff0c;我们写的程序的数据是存储在电脑的内存中&#xff0c;如果程序退出&#xff0c;内存回收&#xff0c;数据就丢失 了&#xff0c;等再次运⾏程序&#xff0c;是看不到上次程序的数据的&#xff0c;如果要将数据进⾏持久…

【C/C++】结构体内存对齐 ----- 面试必考(超详细解析,小白一看就懂!!!)

目录 一、前言 二、引出 ---- 结构体内存对齐 &#x1f34e;结构体偏移量计算&#xff1a;offsetof &#x1f95d;结构体内存对齐详解 &#x1f4a6;规则介绍&#xff08;重点&#xff01;&#xff01;&#xff09; &#x1f4a6;例题解析 三、习题演练 &#x1f34d;练习① …

Spring Cloud 面试题及答案整理,最新面试题

Spring Cloud中断路器的原理及其作用是什么&#xff1f; Spring Cloud断路器的原理和作用基于以下几个关键点&#xff1a; 1、故障隔离机制&#xff1a; 在微服务架构中&#xff0c;断路器作为一种故障隔离机制&#xff0c;当某个服务实例出现问题时&#xff0c;断路器会“断…

Docker知识点总结二

四、 Docker 架构 Docker使用客户端-服务器(C/S)架构模式&#xff0c;使用远程API来管理和创建Docker容器。 介绍&#xff1a; 1、Docker的客户端client&#xff0c;我们在命令行发送一些信息(命令)给Docker服务端。2、中间这个就是Docker的服务端&#xff0c;在这个服务端里面…

漫步者、南卡、Cleer开放式耳机怎么样?硬核对比测评性能强者!

​在当今市场上&#xff0c;开放式耳机的型号层出不穷&#xff0c;作为一名专业的测评博主&#xff0c;我对这类产品有着深入的了解和丰富的经验。最近&#xff0c;我的粉丝们通过私信向我咨询如何选择适合自己的开放式耳机&#xff0c;面对众多品牌的选择&#xff0c;他们感到…

【Unity】使用ScriptableObject存储数据

1.为什么要用ScriptableObject&#xff1f; 在游戏开发中&#xff0c;有大量的配置数据需要存储&#xff0c;这个时候就需要ScriptableObject来存储数据了。 很多人会说我可以用json、xml、txt&#xff0c;excel等等 但是你们有没有想过&#xff0c;假设你使用的是json&#x…

【Linux基础(一)】设备和文件IO

学习分享 1、Linux中的设备管理1.1、设备管理的特点1.2、设备分类1.3、设备工作原理1.4、Linux设备操作1.5、系统调用和系统API等区别 2、文件IO2.1、C库的文件操作2.2、文件描述符2.3、特殊文件描述符2.4、系统调用2.4.1、open系统调用4-12.4.2、open系统调用4-22.4.3、write系…

爬虫实战——伯克利新闻【内附超详细教程,你上你也行】

文章目录 发现宝藏一、 目标二、简单分析网页1. 寻找所有新闻2. 分析模块、版面和文章 三、爬取新闻1. 爬取模块2. 爬取版面3. 爬取文章 四、完整代码五、效果展示 发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不…

2023年扫地机器人行业分析报告(2024年扫地机器人行业未来趋势分析)

当前&#xff0c;随着人们生活水平的提高&#xff0c;扫地机器人因为操作简单、使用方便而越来越多地走入了人们的生活&#xff0c;成为清洁电器中的重要一员&#xff0c;深受消费者欢迎。 伴随科技水平的进步&#xff0c;当前的扫地机器人已经具备了高度智能化的功能&#xf…

C++_位图

目录 1、位图的使用 2、位图实现 3、位图与哈希表的区别 4、位图的应用 结语 前言&#xff1a; 位图采用的是哈希表的思想&#xff0c;哈希表的映射层面是在字节上&#xff0c;而位图的映射层面就是在bit位上。由于bit位所能展现的信息无非只有‘1’和‘0’&#xff0c;所…

【Apple Vision Pro应用源码】Vision Pro吸尘器项目源代码

超级有趣Vision Pro 应用 吸尘器项目 这是一个非常有趣的 Vision Pro项目&#xff0c;会让孩子们爱上打扫卫生。 在这里我展示了如何使用 ARKit&#xff1a;头部跟踪、手部跟踪、场景理解加载和播放声音进程冲突使用 MTLBuffers 处理底层网格数据 项目源代码&#xff1a;Git…

动态规划(算法竞赛、蓝桥杯)--状态压缩DP蒙德里安的梦想

1、B站视频链接&#xff1a;E31 状态压缩DP 蒙德里安的梦想_哔哩哔哩_bilibili #include <bits/stdc.h> using namespace std; const int N12,M1<<N; bool st[N];//st[i]存储合并列的状态i是否合法 long long f[N][M];//f[i][j]表示摆放第i列&#xff0c;状态为…

java-ssm-jsp-大学社团管理系统

java-ssm-jsp-大学社团管理系统 获取源码——》公主号&#xff1a;计算机专业毕设大全

PSINS工具箱笔记——函数定义

绘图函数&#xff1a; 时间进度条&#xff1a; timebar&#xff08;用起来简单&#xff09; 姿态转换&#xff1a; 欧拉角、姿态矩阵、等效旋转矩阵、姿态四元数、运载火箭使用的欧拉角之间的转换。 轨迹生成&#xff1a; seg trjsegment(seg, segtype, lasting, w, a, var…

centos上部署k8s

环境准备 四台Linux服务器 主机名 IP 角色 k8s-master-94 192.168.0.94 master k8s-node1-95 192.168.0.95 node1 k8s-node2-96 192.168.0.96 node2 habor 192.168.0.77 镜像仓库 三台机器均执行以下命令&#xff1a; 查看centos版本 [rootlocalhost Work]# cat /…