首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

剑指offer之找出数组中重复的数字

文章目录 找出数组中重复的数字 方法一 使用hashset 方法二 巧妙采用原地置换法 找出数组中重复的数字 在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。...数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。...set集合中 如果有的话直接输出了 方法二 巧妙采用原地置换法 class Solution { public int findRepeatNumber(int[] nums) {...如果没有重复数字,那么正常排序后,数字i应该在下标为i的位置,所以思路是重头扫描数组,遇到下标为i的数字如果不是i的话,(假设为m),那么我们就拿与下标m的数字交换。...在交换过程中,如果有重复的数字发生,那么终止返回ture 看给的示例 [2, 3, 1, 0, 2, 5, 3] 第一个是2 发现下标为2的元素和2不相等 就和下标为2的元素交换 变成[1, 3, 2,

28310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    剑指offer(一):找出数组中重复的数字

    ❝涓滴之水终可以磨损大石,不是由于它力量强大,而是由于昼夜不舍的滴坠。——贝多芬❞ 找出数组中重复的数字 题目描述 在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内。...数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。...解法二 利用哈希表,遍历数组,如果哈希表中没有该元素,则存入哈希表中,否则返回重复的元素。时间复杂度为 O(n),空间复杂度为 O(n)。...int t = numbers[i]; numbers[i] = numbers[j]; numbers[j] = t; } } 测试用例 长度为 n 的数组中包含一个或多个重复的数字...; 数组中不包含重复的数字; 无效测试输入用例(输入空指针;长度为 n 的数组中包含 0~n-1 之外的数字)。

    65210

    【LeetCode】找出数组中重复的数字day01

    题目 找出数组中重复的数字。 在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的, 但不知道有几个数字重复了,也不知道每个数字重复了几次。...请找出数组中任意一个重复的数字。...则会fasle,那就将这个重复元素return 这里需要注意的是set在进行add得时候其中检查元素重复的复杂度是多少呢?...其中hashSet的add是通过HashMap的key来实现的那么我们了解一下hashMap的putVal()的源码 在put的时候我们会进行插入这个最坏复杂度也在O(n)所以也就是O(n) 将数组进行排序...,然后前后比较,其中java中Arrays.sort使用了两种排序方法,快速排序和优化的合并排序。

    60420

    找出数组中只出现一次的数字

    一个数组中,有一个数字只出现一次,其余的数都出现两次,求出那个单独的数 可以使用异或或来解决这个问题,因为两个相同的数异或之后就是0,0与一个数异或还是这个数,而且异或满足交换律 public static...n ^= arr[i];//与sun+=arr[i]类似,方便理解 } System.out.println(n); } 拓展: 一个数组中...,只有两个不同的数字出现一次,其余的数都出现两次,求出那两个只出现一次的数 思路:假设数组是{1,2,3,1},要想找到那两个只出现一次的数,只需要将数组里面所有的数字异或一下,得到结果sum,然后将...sum进行移位操作判断是否为1,如果不为1,依次往后,知道右移到位为1的时候为止,其实就是确定sum从右往左数第几位是1,从而起到筛选的作用, 接下来将数组遍历一遍,判断数组中的每个数是否满足移k位结果是否为...,所以在异或一个num1就可以得到num2 总结:简单来说,就是通过移位操作来达到分类的作用,接下来就是使用之前异或的方法即可 代码如下 public static int[] Search(int[]

    60530

    找出数组中的所有孤独数字(哈希)

    题目 给你一个整数数组 nums 。如果数字 x 在数组中仅出现 一次 ,且没有 相邻 数字(即,x + 1 和 x - 1)出现在数组中,则认为数字 x 是 孤独数字 。...返回 nums 中的 所有 孤独数字。你可以按 任何顺序 返回答案。...- 8 是一个孤独数字,因为它只出现一次,并且 7 和 9 没有在 nums 中出现。 - 5 不是一个孤独数字,因为 6 出现在 nums 中,反之亦然。...因此,nums 中的孤独数字是 [10, 8] 。 注意,也可以返回 [8, 10] 。...- 5 是一个孤独数字,因为它只出现一次,并且 4 和 6 没有在 nums 中出现。 - 3 不是一个孤独数字,因为它出现两次。 因此,nums 中的孤独数字是 [1, 5] 。

    46230

    找出数组中出现一次的数字

    题目要求 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。...解决方案 有以下三种解决方案: 方法一: //方法一 public int singleNumber(int[] nums){ //1.创建一个Map统计每个数字出现的次数...找出只出现一次的那两个元素。你可以按 任意顺序 返回答案。...解决方案(进阶版本) //把所有的数字还是异或到一起,得到的结果相当于a^b //a^b一定不为0;就可以从异或结果中找到某一个为1的bit位 //要根据这个bit位对整个数组进行分组,...这个bit位为1的第一组,这个比特位为0的是第二组 public int[] singleNumber2(int[] nums){ //先把所有数字异或到一起 int

    23310

    数组中重复的数字

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。...例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 解题思路 最简单的就是用一个数组或者哈希表来存储已经遍历过的数字,但是这样需要开辟额外的空间。...如果题目要求不能开辟额外的空间,那我们可以用如下的方法: 因为数组中的数字都在0~n-1的范围内,所以,如果数组中没有重复的数,那当数组排序后,数字i将出现在下标为i的位置。...现在我们重排这个数组,从头到尾扫描每个数字,当扫描到下标为i的数字时,首先比较这个数字(记为m)是不是等于i。...如果是,则接着扫描下一个数字;如果不是,则再拿它和m 位置上的数字进行比较,如果它们相等,就找到了一个重复的数字(该数字在下标为i和m的位置都出现了),返回true;如果它和m位置上的数字不相等,就把第

    2.1K30

    在字符串中找出连续最长的数字串

    本文链接:https://blog.csdn.net/weixin_42449444/article/details/90137521 题目描述: 读入一个字符串str,输出字符串str中的连续最长的数字串...输出描述: 在一行内输出str中里连续最长的数字串。 输入样例: abcd12345ed125ss123456789 输出样例: 123456789 解题思路: 华为机试、动态规划问题。...设连续最长数字串的长度maxlen、连续最长数字串的起始位置start、临时连续最长数字串的起始位置tempindex、临时连续最长数字串的长度templen。...先找到第一个数字,以它为起始位置找出当前的连续最长数字串的长度templen,若templen>maxlen,就更新连续最长数字串的起始位置和长度。...maxlen、连续最长数字串的起始位置start、临时连续最长数字串的起始位置tempindex for(int i = 0; i < str.length(); i++) {

    2.4K20

    在字符串中找出连续最长的数字串(算法)

    描述 输入一个字符串,返回其最长的数字子串,以及其长度。若有多个最长的数字子串,则将它们全部输出(按原字符串的相对位置) 本题含有多组样例输入。...1<=len(字符串)<=200 输出描述: 输出字符串中最长的数字字符串和它的长度,中间用逗号间隔。如果有相同长度的串,则要一块儿输出(中间不要输出空格)。 思路: 1、首选获取到最长数字是多少。...2、从map里获取最长数字有哪些。 3、再根据下标排序。...a8a72a6a5yy98y65ee1r2 复制 输出: 123058789,9 729865,2 复制 说明: 样例一最长的数字子串为...123058789,长度为9 样例二最长的数字子串有72,98,65,长度都为2 */ public static void main(String[] args) {

    1K20

    查找数组中重复的数字

    题目来源于《剑指Offer》中的面试题3:找出数组中重复的数字。   // 题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内。...数组中某些数字是重复的,但不知道有几个数字重复了,   // 也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。...例如,如果输入长度为7的数组{2, 3, 1, 0, 2, 5, 3},   // 那么对应的输出是重复的数字2或者3。        ...: (输出) 数组中的一个重复的数字 // 返回值: // true - 输入有效,并且数组中存在重复的数字 // false - 输入无效,或者数组中没有重复的数字...numbers, sizeof(numbers) / sizeof(int), duplications, sizeof(duplications) / sizeof(int), true); } // 数组中存在多个重复的数字

    4K60

    数组中的重复数字

    """描述在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。...例如,如果输入长度为7的数组[2,3,1,0,2,5,3],那么对应的输出是2或者3。...存在不合法的输入的话输出-1数据范围:0\le n \le 10000 \0≤n≤10000进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)示例1输入:[2,3,1,0,2,5,3]复制返回值...:2复制说明:2或3都是对的数据范围:0\le n \le 10000 \0≤n≤10000进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)"""# @param numbers int...整型一维数组# @return int整型#from typing import Listclass Solution: def duplicate(self , numbers: List[int

    1.4K10

    如何快速找出数组中出现一半以上的数字

    题目: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。...基本的思路是,在遍历数组过程中,每次找到一对不相等的数,给砍掉,最后活下来的幸存者就是有可能是整个数组中出现的次数超过数组长度的一半的那个数。...而且只需要遍历一遍数组就能够知道那个幸存者是哪个数字。 我们准备两个变量,cand和times,cand为候选数字,而times表示候选数字出现的次数。...在我们的潜意识里,1和2这一对不相等的数已经被砍掉了,妙吧~ ? 3)上一步已经把times置为0了,说明没有候选人了,当我们遍历3的时候,重新把3立为候选人。 ?...10)最后候选人为2,2就有可能是整个数组中出现的次数超过数组长度的一半的那个数 11)重新遍历一遍数组,看看2是不是真的是整个数组中出现的次数超过数组长度的一半的那个数 很明显,只需要两个变量就能完成这个任务

    90720

    剑指offer(二):不修改数组找出重复的数字

    —— 佚名❞ 不修改数组找出重复的数字 题目描述 在一个长度为 n+1 的数组里的所有数字都在 1 到 n 的范围内,所以数组中至少有一个数字是重复的。...请找出数组中任意一个重复的数字,但不能修改输入的数组。例如,如果输入长度为 8 的数组 {2, 3, 5, 4, 3, 2, 6, 7},那么对应的输出是重复的数字 2 或者 3。...解法 解法一 创建长度为 n+1 的辅助数组,把原数组的元素复制到辅助数组中。如果原数组被复制的数是 m,则放到辅助数组第 m 个位置。这样很容易找出重复元素。空间复杂度为 O(n)。...= end) { ++count; } } return count; } } 测试用例 长度为 n 的数组中包含一个或多个重复的数字...; 数组中不包含重复的数字; 无效测试输入用例(输入空指针)。

    80630

    寻找数组中的重复数字

    前言 前面一系列文章分享了数据结构与算法的基础知识,接下来分享一些算法题的解题思路与实现。欢迎各位感兴趣开发者阅读。 问题描述 有一个数组,现要找出数组中任意一个重复的元素。...它的规则如下: 给定一个长度为n的数组,数组中每个元素的取值范围为:0~n-1 数组中某些数字是重复的,但是不知道哪些数字重复了,也不知道重复了几次 求数组中任意一个重复的数字 实现思路 这个问题的实现思路有三种...声明一个数组:[8, 1, 2, 3, 4, 3, 3, 4, 5] 声明一个哈希表: const hashMap = new HashMap() 遍历数组,判断数组中的元素是否在哈希表中。...i = 5时,i号位置的元素为3,在哈希表中,存储i号位置的元素,终止循环。...我们在构造函数中,对调用者传入的参数进行校验。

    1.4K10

    剑指offer第二版(Java最优解)---找出数组中重复的数字

    相当于: int i=0; //用于接收index数组中的某一个对象 for(int j = 0; j<index.length; j++){ i = index[j]; } 从哈希表的思路拓展,...重排数组:把扫描的每个数字(如数字m)放到其对应下标(m下标)的位置上,若同一位置有重复,则说明该数字重复。...代码 带测试用例 * Created by wuyupku on 2019-04-14 15:24 * * @Beijing CHINA */ /* * 题目:在一个长度为n的数组里的所有数字都在...数组中某些数字是重复的,但不知道有几个数字重复了, * 也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。...2.数组中不包含重复的数字 3.无效输入测试用例(空数组,数组数字越界等) ?

    52800

    《剑指Offer》-- 题目一:找出数组中重复的数字(Python多种方法实现)

    数组中重复的数字 最近在复习算法和数据结构(基于Python实现),然后看了Python的各种“序列”——比如列表List、元组Tuple和字符串String,后期会写一篇博客介绍 数组 这一数据结构。...不过我们先来看《剑指Offer》中关于数组的一道面试题。 面试题3:数组中重复的数字 题目一:找出数组中重复的数字 给定一个长度为 n 的数组里的所有数字都在 0∼n−1 的范围内。...数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。 请找出数组中任意一个重复的数字。...利用哈希表:从头到尾按顺序扫描数组的每个数字,每扫到一个数字的时候,如果还没有这个数字,就把它加入哈希表。如果哈希表表中已经存在了该数字,就找到了一个重复的数字。...以下代码都是用Python实现 排序后查找 def find_double_num(nums): """思路一:把输入的数组排序,从排序数组中找出重复的数字 """ nums_sorted

    1.5K10
    领券