day01

1. 找出数组中重复的数字。

在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。

示例 1:

输入:
[2, 3, 1, 0, 2, 5, 3]
输出:2 或 3 
  • 1
  • 2
  • 3

限制:

2 <= n <= 100000

方法一:哈希

class Solution {public int findRepeatNumber(int[] nums) {Set<Integer> set = new HashSet<>();for(int num : nums){if(set.contains(num)) return num;set.add(num);}return -1;}
}

方式二:鸽巢原理(最优解)

class Solution {public int findRepeatDocument(int[] documents) {for(int i=0; i < documents.length; i++){while(i!=documents[i]){if(documents[i]==documents[documents[i]]){return documents[i];}int temp = documents[documents[i]];documents[documents[i]] = documents[i];documents[i] = temp;}}return -1;}
}

以下是算法的执行流程

这种原地置换的想法确实挺精妙的。

1、题目明确说明了数组长度为n,范围为 n-1,也就是若无重复元素排序后下标0123对应的数字就应该是0123;

2、对数组排序,其实也就是让萝卜归位,1号坑要放1号萝卜,2号坑要放2号萝卜......排序过程中查找有无重复元素。先考虑没有重复元素的情况:

 nums[i]     3  1  0  2   萝卜   i       0  1  2  3   坑  

0号坑说我要的是0号萝卜,不要3号萝卜,所以会去和3号坑的萝卜交换,因为如果0号坑拿了3号坑的3号萝卜,那说明3号坑装的也肯定是别人家的萝卜,所以要跟3号坑换,换完是这样的:

 nums[i]     2  1  0  3   萝卜  i       0  1  2  3   坑 

然而0号坑还没找到自己的萝卜,它不要2号萝卜,又去和2号坑的萝卜交换,换完是这样的:

 nums[i]     0  1  2  3   萝卜 i       0  1  2  3   坑  

这时候刚好就是一一对应的,交换过程也不会出现不同坑有相同编号的萝卜。要注意交换用的是while,也就是0号坑只有拿到0号萝卜,1号坑才能开始找自己的萝卜。

3、如果有重复元素,例如:

 nums[i]     1  2  3  2    萝卜i       0  1  2  3    坑

同样的,0号坑不要1号,先和1号坑交换,交换完这样的:

 nums[i]     2  1  3  2    萝卜i       0  1  2  3    坑

0号坑不要2号萝卜,去和2号坑交换,交换完这样的:

 nums[i]     3  1  2  2    萝卜i       0  1  2  3    坑

0号坑不要3号萝卜,去和3号坑交换,交换完这样的:

 nums[i]     2  1  2  3    萝卜i       0  1  2  3    坑

0号坑不要2号萝卜,去和2号坑交换,结果发现你2号坑也是2号萝卜,那我还换个锤子,同时也说明有重复元素出现。

4、总结

其实这种原地交换就是为了降低空间复杂度,只需多要1个坑来周转交换的萝卜就好了,空间复杂度O(1)。

2. 二维数组中的查找

难度中等937

在一个 n * m 的二维数组中,每一行都按照从左到右 非递减 的顺序排序,每一列都按照从上到下 非递减 的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

 

示例:

现有矩阵 matrix 如下:

[[1,   4,  7, 11, 15],[2,   5,  8, 12, 19],[3,   6,  9, 16, 22],[10, 13, 14, 17, 24],[18, 21, 23, 26, 30]
]

给定 target = 5,返回 true

给定 target = 20,返回 false

限制:

0 <= n <= 1000
0 <= m <= 1000

题解:

前置知识: 在二维数组中,如果直接调用b.length方法,返回的是b数组的行数

                   如果是b[0].length方法,则返回的是第0行所代表的长度

思路

答案

class Solution {public boolean findTargetIn2DPlants(int[][] plants, int target) {if(plants==null || plants.length<=0 || plants[0].length<=0){return false;}//从二维数组左下角开始查找int rows = plants.length;int cols = plants[0].length;int row = rows-1;int col = 0;//注意这里行是>=0while(row>=0 && col<cols){if(plants[row][col]>target){row--;}else if(plants[row][col]<target){col++;}else{return true;}}return false;}
}

3. 替换空格

替换空格

用Java api

class Solution {public String pathEncryption(String path) {//思路是根据原来的字符串重新拼接一个字符串StringBuilder builder = new StringBuilder();for(int i=0; i < path.length(); i++){if(path.charAt(i)=='.'){builder.append(' ');}else{builder.append(path.charAt(i));}}return builder.toString();}
}

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

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

相关文章

【问题系列】消费者与MQ连接断开问题解决方案(一)

1. 问题描述 当使用RabbitMQ作为中间件&#xff0c;而消费者为服务时&#xff0c;可能会出现以下情况&#xff1a;在长时间没有消息传递后&#xff0c;消费者与RabbitMQ之间出现连接断开&#xff0c;导致无法处理新消息。解决这一问题的方法是重启Python消费者服务&#xff0c;…

梦极光(ez_re?)

ez_re 先查壳看看&#xff0c;没有壳 32位 我先说说这道题 打开分析找到主函数 在这里就是flag了&#xff0c;用十六进制转ascii码 我们先运行这个程序看看 我想说说我的想法 首先没看出来这里是十六进制转ascii码其次41D538数组用来干啥来的&#xff1f;题目里面给出的请…

Git删除临时分支

愿所有美好如期而遇 软件开发过程中&#xff0c;总有功能要添加进来&#xff0c;当我们有一个功能开发了一半的时候&#xff0c;产品经理说这个功能不需要了&#xff0c;尽管很无奈&#xff0c;但还是要删除&#xff0c;我开发到一半的分支如何删除呢&#xff1f; 所以需要使用…

LeetCode Hot100 84.柱状图中最大的矩形

题目&#xff1a; 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 方法&#xff1a; 代码&#xff1a; class Solution {public int largestRectang…

【UE】绘制抛物线并投射物体

效果 步骤 1. 先新建父类为Actor的蓝图&#xff0c;这里命名为“BP_发射物” 打开“BP_发射物”&#xff0c;添加一个球形的静态网格体和一个发射物移动组件 2. 新建一个父类为角色的蓝图&#xff0c;这里命名为“BP_绘制抛物线” 打开“BP_绘制抛物线” 我们希望可以通过控制…

融云筑基,移动云加速构建高性能智能算力底座

自2022年11月以来&#xff0c;全球大模型数量迅速增加&#xff0c;以ChatGPT为代表的大模型已经成为世界数字科技领域新热点。大模型带来的算力需求迅速增长&#xff0c;未来智算场景将会有非常大的突破空间。 在“十四五”规划的指引下&#xff0c;各地政府积极投入智算中心建…

HTTP2

HTTP 确认访问用户身份的认证 某些Web页面只想让特定的人浏览,或者干脆仅本人可见。为达到这个目标,必不可少的就是认证功能。 何为认证 计算机本身无法判断坐在显示器前的使用者的身份。进一步说,也无法确认网络的那头究竟有谁。可见,为了弄清究竟是谁在访问服务器,就…

一种新的基于物理的AlGaN/GaN HFET紧凑模型

标题&#xff1a;A new physics-based compact model for AlGaN/GaN HFETs (IEEE MTT-S International Microwave Symposium) 摘要 摘要 - 针对AlGaN/GaN HFET&#xff0c;提出了一种无拟合参数的物理解析模型。对于非饱和操作&#xff0c;建立了两个接入区和栅极下方I-V特性的…

2023.11.27 关于 Mybatis 增删改操作

目录 引言 增加用户操作 删除用户操作 修改用户操作 阅读下述文章之间 建议点击下方链接先了解 MyBatis 的创建与使用 MyBatis 的创建与使用 建议点击下方链接先了解 单元测试 的创建与使用 Spring Boot 单元测试的创建与使用 引言 为了方便下文实现增、删、改操作我们先…

YOLO改进系列之SKNet注意力机制

摘要 视皮层神经元的感受野大小受刺激的调节即对于不同的刺激&#xff0c;卷积核的大小应该不同&#xff0c;但在构建CNN时一般在同一层只采用一种卷积核&#xff0c;很少考虑因采用不同卷积核。于是SKNet被提出&#xff0c;在SKNet中&#xff0c;不同大小的感受视野&#xff…

基于JavaWeb+SSM+Vue校园综合服务小程序系统的设计和实现

基于JavaWebSSMVue校园综合服务小程序系统的设计和实现 源码获取入口Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 Lun文目录 摘 要 I Abstract II 第一章 绪 论 1 1.1选题背景 2 1.2研究现状 3 1.3研究内容 …

【蓝桥杯省赛真题48】Scratch放大镜游戏 蓝桥杯scratch图形化编程 中小学生蓝桥杯省赛真题讲解

目录 scratch放大镜游戏 一、题目要求 编程实现 二、案例分析 1、角色分析