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

力扣 寻找重复数

二分,双指针,环形链表。

题目

不看完题就是排序后,用两个快慢指针移动,找到相同就返回即可。

class Solution {public int findDuplicate(int[] nums) {Arrays.sort(nums);int l=0;int r=1;while(r<nums.length){if(nums[l]==nums[r])return nums[r];l++; r++;}return -1;}
}

但是题要求不修改数组,因此肯定不会那么简单。先是二分查找法,由题可知,nums只有一个重复的数,且数字的大小在1到n,那么可以直接看nums[i],去遍历每个数值,然后用一个计数器去记录i,注意假设nums[x]找到了这个数,那后面的计数器nums[x+1]都是加一的,然后二分划分区间,没有重复的在左半区,重复数后的在右半区,重复数就是要找的mid。如果比目标值即重复的数小说明没有,跟目标值相等说明刚好一个,说明当前没有找到重复的数,比目标值大说明就是找到了重复数的区间,继续收缩。然后就是二分的模板了,注意比较时是比数值不是比索引。

时间复杂度: O(nlogn),空间复杂度: O(1)。

class Solution {public int findDuplicate(int[] nums) {int n = nums.length;int l = 1, r = n - 1, ans = -1;while (l <= r) {int mid = (l + r) >> 1;int cnt = 0;for (int i = 0; i < n; ++i) {if (nums[i] <= mid) {cnt++;}}if (cnt <= mid) {l = mid + 1;} else {r = mid - 1;ans = mid;}}return ans;}
}

接着是快慢指针,龟兔赛跑算法。这题由于索引跟元素值的限定范围,假如按索引指向的数值当作下一个索引,如此往复,是可以形成一个环的,即假设走到某个k+1点时指向的数值是k,然后去到索引k,索引k的数值是k+2,然后k+2的数值又是k,如此反复,这里是可以形成一个环的,而这个k+1时就是环的入口点,也是要找的重复值。然后用快慢指针,慢指针每次走一步,快指针每次走两步,相遇一次后做标记,慢指针归零,从新出发,快指针从环里出发,然后再次相遇即可找到入口点了。慢指针走一步 slow = slow.next,快指针走两步 fast = fast.next.next,换成数组就是包多一层即可。注意要排除形成自环,即索引的数值是本身,因此从零出发可以排除。

时间复杂度: O(n),空间复杂度: O(1)。

class Solution {public int findDuplicate(int[] nums) {int slow = 0, fast = 0;//初始化是相等的,所以先执行,第一次相遇找到标记点do {slow = nums[slow];fast = nums[nums[fast]];} while (slow != fast);//慢指针重新出发,快指针继续在环里走slow = 0;while (slow != fast) {slow = nums[slow];fast = nums[fast];}return slow;}
}

 

相关文章:

力扣 寻找重复数

二分&#xff0c;双指针&#xff0c;环形链表。 题目 不看完题就是排序后&#xff0c;用两个快慢指针移动&#xff0c;找到相同就返回即可。 class Solution {public int findDuplicate(int[] nums) {Arrays.sort(nums);int l0;int r1;while(r<nums.length){if(nums[l]num…...

第48天:Web开发-JavaEE应用依赖项Log4j日志Shiro验证FastJson数据XStream格式

#知识点 1、安全开发-JavaEE-第三方依赖开发安全 2、安全开发-JavaEE-数据转换&FastJson&XStream 3、安全开发-JavaEE-Shiro身份验证&Log4j日志处理 一、Log4j 一个基于Java的日志记录工具&#xff0c;当前被广泛应用于业务系统开发&#xff0c;开发者可以利用该工…...

ES6笔记总结

首先我们需要了解一下什么是 ECMA&#xff1a; ECMA&#xff08;European Computer Manufacturers Association&#xff09;中文名称为欧洲计算机制造商协会&#xff0c;这 个组织的目标是评估、开发和认可电信和计算机标准。1994 年后该组织改名为 Ecma 国际 什么是 ECMAScr…...

使用Docker Desktop部署GitLab

1. 环境准备 确保Windows 10/11系统支持虚拟化技术&#xff08;需在BIOS中开启Intel VT-x/AMD-V&#xff09;内存建议≥8GB&#xff0c;存储空间≥100GB 2. 安装Docker Desktop 访问Docker官网下载安装包安装时勾选"Use WSL 2 instead of Hyper-V"&#xff08;推荐…...

经典算法 统计数字问题(常数时间解决)

统计数字问题 一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排&#xff0c;每个页码都不含多余的前导数字0。例如&#xff0c;第6 页用数字6 表示&#xff0c;而不是06 或006 等。数字计数问题要求对给定书的总页码n&#xff0c;计算出书的全部页…...

基于yolov8的糖尿病视网膜病变严重程度检测系统python源码+pytorch模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv8的糖尿病视网膜病变严重程度检测系统 基于YOLOv8的糖尿病视网膜病变严重程度检测系统是一款利用深度学习技术&#xff0c;专为糖尿病视网膜病变早期诊断设计的智能辅助工具。该系统采用YOLOv8目标检测模型&#xff0c;结合经过标注和处理的医学影像数…...

AcWing 5933:爬楼梯 ← 递归 / 递推 / 高精度

【题目来源】 https://www.acwing.com/problem/content/5936/ 【题目描述】 树老师爬楼梯&#xff0c;他可以每次走 1 级或者 2 级&#xff0c;输入楼梯的级数&#xff0c;求不同的走法数。 例如&#xff1a;楼梯一共有 3 级&#xff0c;他可以每次都走一级&#xff0c;或者第…...

c++ 中的容器 vector 与数组 array

当初自学 c 与 c 语言时&#xff0c;一直被指针弄的云里雾里。后来 c 中引入了容器&#xff0c;避免了指针。但是&#xff0c;一些教材把容器的章节放在书本中后面的章节&#xff0c;太不合理。应该把这种方便的功能放到前面&#xff0c;这样一些初学者就不会遇到太多生硬难懂的…...

我的世界1.20.1forge模组开发进阶物品(7)——具有动画、3D立体效果的物品

基础的物品大家都会做了对吧?包括武器的释放技能,这次来点难度,让物品的贴图呈现动画效果和扔出后显示3D立体效果,这个3D立体效果需要先学习blockbench,学习如何制作贴图。 Blockbench Blockbench是一个用于创建和编辑三维模型的免费软件,特别适用于Minecraft模型的设计…...

ubuntu22.04安装docker engine

在Ubuntu 22.04上安装Docker Engine可以通过以下步骤完成&#xff1a; 更新系统包索引&#xff1a; sudo apt update安装必要的依赖包&#xff1a; 这些包允许apt通过HTTPS使用仓库。 sudo apt install -y apt-transport-https ca-certificates curl software-properties-commo…...

性能测试测试策略制定|知名软件测评机构经验分享

随着互联网产品的普及&#xff0c;产品面对的用户量级也越来越大&#xff0c;能抗住指数级增长的瞬间访问量以及交易量是保障购物体验是否顺畅的至关重要的一环&#xff0c;而我们的性能测试恰恰也是为此而存在的。 性能测试是什么呢&#xff1f;性能测试要怎么测呢&#xff1f…...

Let‘s Encrypt免费证书的应用示例

文章目录 前言证书申请证书介绍cert.pemchain.pemfullchain.pemprivkey.pem 使用步骤搭建简易demo应用新建nginx配置文件测试SSL是否生效 总结 前言 最近在搞苹果应用上架的问题&#xff0c;据说用HTTP会被拒&#xff0c;但貌似不绝对&#xff0c;2017年苹果曾发公告说必须要求…...

threeJS——安装以及三要素

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、安装二、三要素1.场景1.1创建场景1.2向场景添加元素1.3场景属性 2.相机2.1相机特点2.2正交相机2.3空间布局2.4小姐操作 3.渲染器 总结 前言 本章简单介绍前…...

【Electron入门】进程环境和隔离

目录 一、主进程和渲染进程 1、主进程&#xff08;main&#xff09; 2、渲染进程&#xff08;renderer&#xff09; 二、预加载脚本 三、沙盒化 为单个进程禁用沙盒 全局启用沙盒 四、环境访问权限控制&#xff1a;contextIsolation和nodeIntegration 1、contextIsola…...

提示词框架介绍和使用场景

框架介绍 CO-STAR 框架 定义 CO-STAR是六个关键要素的缩写,每个字母代表一个特定的部分: Context(上下文) :提供任务的背景信息或环境 当前任务是为一家科技公司撰写一篇关于人工智能发展趋势的文章/ 需要为一场面向高中生的科普讲座准备内容Objective(目标) :明确任…...

牛客NC288803 和+和

​import java.util.Comparator;import java.util.PriorityQueue;import java.util.Scanner;​public class Main {public static void main(String[] args) {// 创建Scanner对象用于读取输入Scanner sc new Scanner(System.in);// 读取两个整数n和m&#xff0c;分别表示数组的…...

AI学习第七天

数组&#xff1a;基础概念、存储特性及力扣实战应用 在计算机科学与数学的广袤领域中&#xff0c;数组作为一种极为重要的数据结构&#xff0c;发挥着不可或缺的作用。它就像一个有序的 “数据仓库”&#xff0c;能高效地存储和管理大量数据。接下来&#xff0c;让我们深入了解…...

【uniapp原生】实时记录接口请求延迟,并生成写入文件到安卓设备

在开发实时数据监控应用时&#xff0c;记录接口请求的延迟对于性能分析和用户体验优化至关重要。本文将基于 UniApp 框架&#xff0c;介绍如何实现一个实时记录接口请求延迟的功能&#xff0c;并深入解析相关代码的实现细节。 前期准备&必要的理解 1. 功能概述 该功能的…...

XR应用测试:探索虚拟与现实的边界

引言 随着XR&#xff08;扩展现实&#xff0c;Extended Reality&#xff09;技术的快速发展&#xff0c;VR&#xff08;虚拟现实&#xff09;、AR&#xff08;增强现实&#xff09;和MR&#xff08;混合现实&#xff09;应用逐渐渗透到游戏、教育、医疗、工业等多个领域。对于…...

算法之算法思想

算法思想 ♥算法思想知识体系详解♥ | Java 全栈知识体系 经典算法思想总结 经典算法思想总结&#xff08;含LeetCode题目推荐&#xff09; | JavaGuide...

别再只跑Demo了!手把手教你用YOLOv5/v8训练自己的钢材缺陷数据集并部署成Web服务

从零构建工业级钢材缺陷检测系统&#xff1a;YOLOv5/v8实战全流程指南 在工业质检领域&#xff0c;深度学习技术正在掀起一场革命。想象一下&#xff0c;当传统质检员需要花费数小时仔细检查钢材表面的每一寸区域时&#xff0c;一个训练有素的AI系统可以在几毫秒内完成同样的工…...

Qtile扩展开发终极指南:编写自定义命令和工具的完整教程

Qtile扩展开发终极指南&#xff1a;编写自定义命令和工具的完整教程 【免费下载链接】qtile :cookie: A full-featured, hackable tiling window manager written and configured in Python (X11 Wayland) 项目地址: https://gitcode.com/gh_mirrors/qt/qtile Qtile是一…...

Unity | HDRP高清渲染管线实战:优化Lightmapping性能的10个关键技巧

1. 理解HDRP中的Lightmapping核心机制 在HDRP高清渲染管线中&#xff0c;光照烘焙&#xff08;Lightmapping&#xff09;是将复杂光照计算转化为纹理贴图的关键技术。与实时渲染不同&#xff0c;烘焙过程会预先计算场景中静态物体的间接光照、阴影和环境光遮蔽效果&#xff0c;…...

MySQL 索引特性与性能优化全解

&#x1f525;草莓熊Lotso&#xff1a;个人主页 ❄️个人专栏: 《C知识分享》 《Linux 入门到实践&#xff1a;零基础也能懂》 ✨生活是默默的坚持&#xff0c;毅力是永久的享受&#xff01; &#x1f3ac; 博主简介&#xff1a; 文章目录前言&#xff1a;一. 索引是什么1.1 初…...

linux学习进展 基础命令 vi基础命令

Linux系统的核心操作依赖命令行&#xff0c;掌握基础命令是入门Linux的关键&#xff0c;而vi编辑器作为Linux自带的文本编辑工具&#xff0c;日常使用频率极高。本次笔记主要记录Linux常用基础命令及vi编辑器的核心操作&#xff0c;方便后续复习巩固&#xff0c;兼顾实用性和易…...

Visio是什么?附安装使用全流程

Visio是什么&#xff1f; 它是微软出品的专业图表绘制工具&#xff0c;是Office家族里最低调、但也是职场进阶最硬核的成员之一。如果说Excel是处理数字的神&#xff0c;那Visio就是处理逻辑和流程的王者。 安装教程和安装包获取 为什么建议你试试Visio&#xff1f; 1. 拖拽…...

快马AI助力:十分钟用openclaw搭建局域网访问服务原型

今天想和大家分享一个快速搭建局域网访问服务原型的经验。最近在做一个内部项目&#xff0c;需要让团队成员能方便地访问我本地开发的服务&#xff0c;于是想到了用openclaw这个工具来实现内网穿透。整个过程比想象中简单很多&#xff0c;特别是在InsCode(快马)平台的帮助下&am…...

Python 数据库操作:精准获取指定行指定列的完整指南

🎯 Python 数据库操作:精准获取指定行指定列的完整指南 下面给你分场景、给可直接运行的代码,覆盖所有常用需求,从基础到进阶一次性讲透。 一、核心前提:先拿到完整结果集 基于你之前的代码,我们先拿到所有数据和字段名: # 执行查询 sql = "SELECT * FROM user…...

测试数据管理:告别“脏数据”的困扰

在软件测试的日常实践中&#xff0c;测试数据是驱动一切验证活动的血液。然而&#xff0c;这至关重要的“血液”却常常受到“脏数据”的污染&#xff0c;导致测试用例失效、结果失真&#xff0c;最终侵蚀产品质量的基石。所谓“脏数据”&#xff0c;并非字面意义上的污秽&#…...

解密技术的范式革新:RPGMakerDecrypter如何重构游戏创作生态

解密技术的范式革新&#xff1a;RPGMakerDecrypter如何重构游戏创作生态 【免费下载链接】RPGMakerDecrypter Tool for decrypting and extracting RPG Maker XP, VX and VX Ace encrypted archives and MV and MZ encrypted files. 项目地址: https://gitcode.com/gh_mirror…...