当前位置: 首页 > news >正文

经典双指针算法试题(一)

在这里插入图片描述


📘北尘_:个人主页

🌎个人专栏:《Linux操作系统》《经典算法试题 》《C++》 《数据结构与算法》

☀️走在路上,不忘来时的初心

文章目录

  • 一、移动零
    • 1、题目讲解
    • 2、讲解算法原理
    • 3、代码实现
  • 二、复写零
    • 1、题目讲解
    • 2、讲解算法原理
    • 3、代码实现
  • 三、盛水最多的容器
    • 1、题目讲解
    • 2、讲解算法原理
    • 3、代码实现
  • 四、快乐数
    • 1、题目讲解
    • 2、讲解算法原理
    • 3、代码实现


一、移动零

1、题目讲解

在这里插入图片描述

2、讲解算法原理

在这里插入图片描述

3、代码实现

class Solution {
public:void moveZeroes(vector<int>& nums) {for(int cur=0,dest=0;cur<nums.size();cur++){if(nums[cur]){swap(nums[cur],nums[dest++]);}}}
};

二、复写零

1、题目讲解

在这里插入图片描述

2、讲解算法原理

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3、代码实现

class Solution {
public:void duplicateZeros(vector<int>& arr) {int cur=0,dest=-1,n=arr.size();while(cur<n){if(arr[cur]) dest++;else dest+=2;if(dest>=n-1) break;cur++;}if(dest==n){arr[n-1]=0;cur--;dest-=2;}while(cur>=0){if(arr[cur]) arr[dest--]=arr[cur--];else {arr[dest--]=0;arr[dest--]=0;cur--;}  }  }
};

三、盛水最多的容器

1、题目讲解

在这里插入图片描述
在这里插入图片描述

2、讲解算法原理

在这里插入图片描述

3、代码实现

class Solution {
public:int maxArea(vector<int>& height) {int max=0,begin=0,end=height.size()-1;while(begin<end){if(height[begin]>height[end]){int v1=height[end]*(end-begin);if(v1>max)max=v1;--end;}else{int v2=height[begin]*(end-begin);if(v2>max)max=v2;++begin;}}return max;}
};

四、快乐数

1、题目讲解

在这里插入图片描述

2、讲解算法原理

在这里插入图片描述

3、代码实现

class Solution {
public:int bigsum(int n ){int sum=0;while(n){int ret=n%10;sum+=ret*ret;n/=10;}return sum;}bool isHappy(int n) {int slow=n,fast=bigsum(n);while(fast!=slow){fast=bigsum(bigsum(fast));slow=bigsum(slow);}return slow==1;}
};

相关文章:

经典双指针算法试题(一)

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、移动零1、题目讲解2、讲解算法原理3、代码实现 二、复写零1、题目讲解2、讲解算法原理3、…...

MATLAB | 绘图复刻(十三) | 带NaN图例的地图绘制

有粉丝问我地图绘制如何添加NaN&#xff0c;大概像这样&#xff1a; 或者这样&#xff1a; 直接上干货&#xff1a; 原始绘图 假设我们有这样的一张图地图&#xff0c;注意运行本文代码需要去matlab官网下载Mapping Toolbox工具箱&#xff0c;但是其实原理都是相似的&…...

netty整合websocket(完美教程)

websocket的介绍&#xff1a; WebSocket是一种在网络通信中的协议&#xff0c;它是独立于HTTP协议的。该协议基于TCP/IP协议&#xff0c;可以提供双向通讯并保有状态。这意味着客户端和服务器可以进行实时响应&#xff0c;并且这种响应是双向的。WebSocket协议端口通常是80&am…...

选择PC示波器的10种理由!

PC示波器&#xff08;PCs&#xff09;在测试仪器领域中的关键项目上正迅速地取代传统的数字存储示波器&#xff08;DSOs&#xff09;&#xff0c;其中有十个理由&#xff1a; 小巧和便携示波器利用你的PC显示器实现大屏幕和精细彩色显示信号存储只受限于你的PC存储器大小捕捉波…...

【pytorch深度学习 应用篇02】训练中loss图的解读,训练中的问题与经验汇总

文章目录 loss图解析train loss ↘ \searrow ↘ ↗ \nearrow ↗ 先降后升 loss图解析 train loss ↘ \searrow ↘ 不断下降&#xff0c;test loss ↗ \nearrow ↗ 不断上升&#xff1a;原因很多&#xff0c;我是把workers1&#xff0c;batchSize8192train loss ↘ \searro…...

uniapp 微信小程序如何实现多个item列表的分享

以下代码是某个循环里面的item <button class"cu-btn" style"background-color: transparent;padding: 0;"open-type"share" :data-tree"item.treeId" :data-project"item.projectId"v-if"typeId1 && userI…...

.NET 8 正式 GA 遥遥领先

.NET 8 一正式 已正式 GA。 微软称 .NET 8 提供了数以千计的性能、稳定性和安全性改进&#xff0c;以及平台和工具增强功能&#xff0c;有助于提高开发者的工作效率和创新速度。 比如 .NET 8 为 Android 和 WASM 引入了全新的 AOT 模式、改进 System.Text.Json&#xff0c;以…...

2216. 美化数组的最少删除数 --力扣 --JAVA

题目 给你一个下标从 0 开始的整数数组 nums &#xff0c;如果满足下述条件&#xff0c;则认为数组 nums 是一个 美丽数组 &#xff1a; nums.length 为偶数对所有满足 i % 2 0 的下标 i &#xff0c;nums[i] ! nums[i 1] 均成立 注意&#xff0c;空数组同样认为是美丽数组。…...

DDD 领域驱动设计

文章目录 请解释下什么是 DDD 领域驱动设计DDD 的四层领域模型是怎样的&#xff1f;包含哪些基础概念&#xff1f;DDD 中的贫血模型和充血模型有什么区别在 DDD 中&#xff0c;如何处理模型的聚合和聚合根DDD 中的实体和值对象有什么区别&#xff1f;在 DDD 中&#xff0c;如何…...

转型做视频了,博客就是稿子,继续坚持写博客,同时发布视频,能写博客说明思路清晰了,能再讲明白,理解就更透彻了,紧跟上时代发展。

1&#xff0c;今天特别记录下&#xff0c;B站给开通了《合集》功能 最近使用视频制作了几个视频。播放量还不错&#xff0c;最好的已经到了 2.6K了。 然后粉丝也涨到了 200个。 添加链接描述 紧跟时代&#xff1a;从写博客到录视频&#xff0c;粉丝大涨&#xff0c;突破200个&…...

小众市场:探索跨境电商中的利基领域

随着全球数字化和互联网的普及&#xff0c;跨境电子商务已经成为了一个蓬勃发展的产业。从亚马逊到阿里巴巴&#xff0c;大型电商平台已经占据了很大一部分市场份额。 然而&#xff0c;在这个竞争激烈的领域&#xff0c;寻找小众市场和利基领域可能是一种成功的策略。本文将探…...

C++中的mutable关键字

mutable是C中的一个关键字&#xff0c;它用来修饰类的成员变量。 当我们将一个成员变量声明为mutable时&#xff0c;就意味着这个成员变量可以被类的任何方法修改&#xff0c;即使这个方法是const类型的。这是因为mutable关键字可以打破const类型的限制&#xff0c;使得const类…...

java: 无效的目标发行版: 17 问题解决

今天在写完类点击运行后显示java: 无效的目标发行版: 17 网上查询了一番&#xff0c;发现有几个地方需要注意。 还有一个就是设置中&#xff0c;下面的就是我本次问题所在&#xff0c;不知道为什么&#xff0c;他自动添加了下面的东西 一个方法是把目标字节码版本改为正确的&a…...

C#的LINQ查询

当使用LINQ&#xff08;Language Integrated Query&#xff09;查询时&#xff0c;我们可以在C#中以一种类似于SQL的语法来查询数据。LINQ提供了一种统一的方式来查询各种数据源&#xff0c;如集合、数据库、XML等。 在上述示例中&#xff0c;我们使用LINQ查询来将两个列表根据…...

Python不会调试不够丝滑?那事你不会logging---剖析!

前言: 一直都是手动debug进行调试,F8都按烂了;最近用logging进行提前布置,发现这样更能让代码走得丝滑,同时也能尽早发现问题! 基本概念&#xff1a; Logger - 日志记录接口 Handler - 确定日志记录发送到不同的地方&#xff08;文件、控制台等&#xff09; Level - 定义了日…...

OpenAI的Whisper蒸馏:蒸馏后的Distil-Whisper速度提升6倍

1 Distil-Whisper诞生 Whisper 是 OpenAI 研发并开源的一个自动语音识别&#xff08;ASR&#xff0c;Automatic Speech Recognition&#xff09;模型&#xff0c;他们通过从网络上收集了 68 万小时的多语言&#xff08;98 种语言&#xff09;和多任务&#xff08;multitask&am…...

Ubuntu18.04安装LeGO-LOAM保姆级教程

系统环境&#xff1a;Ubuntu18.04.6 LTS 1.LeGO-LOAM的安装前要求&#xff1a; 1.1 ROS安装&#xff1a;参考我的另一篇博客Ubuntu18.04安装ROS-melodic保姆级教程_灬杨三岁灬的博客-CSDN博客文章浏览阅读168次。Ubuntu18.04安装ROS-melodic保姆级教程https://blog.csdn.net/…...

git修改commit历史提交时间、作者

1、修改最近的几条记录&#xff0c;进入提交记录列表&#xff0c;修改提交记录模式 git rebase -i HEAD~3 // 修改最近的三条记录&#xff0c;顺序排列按提交时间升序 指令说明&#xff1a; pick&#xff1a;保留该commit&#xff08;缩写:p&#xff09; reword&#xff1a…...

【C++历练之路】list的重要接口||底层逻辑的三个封装以及模拟实现

W...Y的主页 &#x1f60a; 代码仓库分享&#x1f495; &#x1f354;前言&#xff1a; 在C的世界中&#xff0c;有一种数据结构&#xff0c;它不仅像一个神奇的瑰宝匣&#xff0c;还像一位能够在数据的海洋中航行的智慧舵手。这就是C中的list&#xff0c;一个引人入胜的工具…...

Kubeadm部署Kubernetes Containerd集群

文章目录 概述一、硬件系统二、基础配置设置主机名配置主机名与IP地址解析关闭防火墙与selinux时间同步(ntp)升级系统内核配置内核转发及网桥过滤*安装ipset及ipvsadm关闭SWAP分区 三、Containerd准备Containerd获取下载解压Containerd配置文件生成并修改Containerd启动及开机自…...

Rust FFI与C交互:跨语言编程实践

Rust FFI与C交互&#xff1a;跨语言编程实践 引言 大家好&#xff0c;我是一名正在从Rust转向Python的后端开发者。在实际项目中&#xff0c;我们经常需要与其他语言进行交互&#xff0c;特别是C语言。Rust提供了强大的FFI&#xff08;Foreign Function Interface&#xff09…...

可训练对数线性稀疏注意力机制:原理与工程实践

1. 项目背景与核心价值在深度学习领域&#xff0c;注意力机制已经成为Transformer架构的核心组件。然而传统注意力机制的计算复杂度随着序列长度呈平方级增长&#xff0c;这严重限制了模型处理长序列的能力。我们团队开发的"可训练对数线性稀疏注意力机制"正是为了解…...

Unity性能优化实战:用Magica Cloth的Virtual Deformer把高模裙子顶点数砍掉80%

Unity性能优化实战&#xff1a;Magica Cloth虚拟变形器实现高模裙子顶点数缩减80% 在角色表现力与性能消耗的天平上&#xff0c;技术美术常常需要做出艰难抉择。当项目中的女性角色穿着繁复的裙装时&#xff0c;传统布料模拟方案往往让移动设备GPU不堪重负。Magica Cloth的Virt…...

使用CGAL构建完美球体网格

在计算机图形学和几何处理中,构建高质量的球体网格(sphere mesh)是许多应用的基础。CGAL(Computational Geometry Algorithms Library)提供了丰富的工具来处理几何问题。本文将详细介绍如何使用CGAL中的SurfaceMesh数据结构来生成一个规则的球体网格,并展示如何通过Loop细…...

Unity MCP服务器:AI助手与Unity编辑器深度集成的开发新范式

1. 项目概述&#xff1a;Unity与MCP的桥梁如果你是一名Unity开发者&#xff0c;并且对AI驱动的开发流程感兴趣&#xff0c;那么你很可能已经听说过“MCP”&#xff08;Model Context Protocol&#xff09;。简单来说&#xff0c;MCP是一个旨在让AI助手&#xff08;比如Claude、…...

【Python实战】一键群发千人定制邮件!基于Excel+模板的自动化群发脚本

一、环境准备与安装 基础环境&#xff1a;Python 3.8 安装依赖&#xff1a;一行命令搞定 pip install pandas openpyxl pyyaml⚡ 二、三步极简上手 第一步&#xff1a;配置SMTP邮箱 编辑 config.yaml&#xff0c;填入你的邮箱和授权码&#xff08;⚠️ 注意是授权码&#…...

如何高效阅读c语言函数(形成线思维和面思维)

最近&#xff0c;我在阅读linux内核源码&#xff0c;由于代码量太大了&#xff0c;有成百个源文件&#xff0c;源文件中有成千上万的函数&#xff0c;我本来的计划是对每一个源文件中的函数自上而下粗略读一遍&#xff08;不会跳转到子函数中去看子函数是如何实现的&#xff09…...

如何将CT-MPI影像组学特征与冠心病大血管及微循环机制建立关联,并进一步解释其与主要不良心血管事件(MACE)预后的机制联系

01导语各位同学&#xff0c;大家好。做影像组学&#xff0c;如果还停留在“提特征—建模型—算AUC”三板斧&#xff0c;那就像算命先生——算得再准&#xff0c;问起“凭什么”&#xff0c;也只能支支吾吾。别人一质疑&#xff1a;你那些纹理、百分位数到底代表什么生物学过程&…...

周红伟SEO能力加强和客户转化的能力点

&#x1f9ec; 周红伟老师背景速览维度内容身份定位大数据与人工智能实战专家 / 企业培训讲师核心背书法国科学院数据算法博士、前阿里AI专家、前马上消费风控负责人、前猪八戒大数据科学家主要平台CSDN博客&#xff08;AI周红伟&#xff09;、讲师宝、企业管理咨询网、京城名师…...

Ozon选品工具怎么选?一篇讲透主流工具优劣势

工具选对了&#xff0c;每天省下3小时&#xff1b;选错了&#xff0c;越用越累还不出单做Ozon选品&#xff0c;光靠手动翻热销榜&#xff0c;一天扒几十个品就耗尽精力。市面上选品工具五花八门&#xff0c;功能各有侧重。这篇文章不吹不黑&#xff0c;从新手视角横向对比目前主…...