广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python不修改数组怎么找出重复的数字
  • 157
分享到

Python不修改数组怎么找出重复的数字

2023-06-30 14:06:29 157人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

这篇“python不修改数组怎么找出重复的数字”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python不修改数组怎么找出重

这篇“python不修改数组怎么找出重复的数字”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python不修改数组怎么找出重复的数字”文章吧。

    数组中重复的数字

    在上一篇博客中剑指Offer之面试题3: 数组中重复的数字中,其实能发现这类题目的关键就是一边遍历数组一边查满足条件的元素。

    然后我们在博客用最复杂的方式学会数组(Python实现动态数组)这篇博客中介绍了数组这一结构的本质,并自己动手实现了一个动态数组。

    今天我们介绍一下另一道来自《剑指Offer》的关于数组的面试题——不修改数组找出重复的数字。

    不修改数组找出重复的数字

    题目二:不修改数组找出重复的数字

    给定一个长度为 n+1 的数组里的所有数字都在 0∼n 的范围内,所以数组中至少有一个数字是重复的。

    请找出数组中任意一个重复的数字,但不能修改输入的数组。

    样例:

    给定长度为8的数组 nums = [2, 3, 5, 4,3, 2, 6,7]

    那么输出重复的数字2或者3

    思路

    首先我们得关注到,题目要求是:不修改数组,然后还是  返回任意一个重复的数字 。所以解题思路相比而言变少了:

    哈希表:跟上一题一样,本题也可以创建一个哈希表,如果原数组的每个数字第一次出现,就把他放到哈希表中去,即原数组大小为m的数字应该放到哈希表下标为m的位置上。空间复杂度是 $O(n)$ 。

    二分法:那么有没有不用空间复杂度 $O(n)$ 的算法。假设没有重复数,那么1~n 之间,每个数都只能出现一次。而题目中,这个数组至少有一个数字重复,即出现的次数大于1。

    利用二分的思想:把 1~n 的数字从中间数字 m 开始分为两部分,前一半为 1~ m,后面一半为 m+1 ~n,如果 1~m 中的数字在数组中出现的次数大于 m,那么这一半必定有重复的数字;

    否则,那么另一部分必定含有重复数字。接着我们,继续对含有重复数字的区间一分为二,直到找到重复的数字。

    思路一:哈希表

    def find_duplicated_num(nums):    """hash_map"""    hash_map = dict()    for i, val in enumerate(nums):        if val in hash_map:            return val        hash_map[val] = i    return False

    思路二:二分法

    def reduce_inter(nums2, left, right):    """ """    mid = (left + right) // 2    count = 0    length = len(nums2)    for i in range(length):        if (nums2[i] >= left) and (nums2[i] <= mid):            count += 1    if count > mid - left + 1:        return left, mid    else:        return mid+1, rightdef find_duplicated_num2(nums2):    left, right = 1, len(nums2) - 1    while left != right:        left, right = reduce_inter(nums2, left, right)    return left

    测试

    nums = [2, 3, 5, 4, 3, 2, 6, 7]# nums_n = [5, 4, 3, 2, 6, 7]print("思路一测试结果: ", find_duplicated_num(nums))print("思路二测试结果: ", find_duplicated_num2(nums))

    结果

    思路一测试结果:  3
    思路二测试结果:  3

    以上就是关于“Python不修改数组怎么找出重复的数字”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网Python频道。

    --结束END--

    本文标题: Python不修改数组怎么找出重复的数字

    本文链接: https://www.lsjlt.com/news/329833.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Python不修改数组怎么找出重复的数字
      这篇“Python不修改数组怎么找出重复的数字”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python不修改数组怎么找出重...
      99+
      2023-06-30
    • Python面试不修改数组找出重复的数字
      目录数组中重复的数字不修改数组找出重复的数字思路思路一:哈希表思路二:二分法测试总结数组中重复的数字 在上一篇博客中剑指Offer之面试题3: 数组中重复的数字中,其实能发现这类题目...
      99+
      2022-11-11
    • java如何找出数组中的不重复数字
      找出数组中不重复的一个数字,题目大致是这样的:int[] a = { 1, 2, 3, 4, 3, 2, 1 };在线视频教程推荐:java在线学习解决办法是:public static int getNoRepeat() { int[]...
      99+
      2018-07-23
      java 数组 不重复 数字
    • c语言怎么找出数组中重复的数字
      可以使用两种方法来找出数组中重复的数字。 方法一:使用“哈希表” 创建一个哈希表,用于记录每个数字出现的次数。 遍历数组,将数组中...
      99+
      2023-10-26
      c语言
    • python怎么找出字符串的重复字符
      可以使用Python的set()函数来找出字符串中的重复字符。set()函数会将字符串转换成一个集合,集合中的元素是唯一的。我们可以...
      99+
      2023-10-11
      Python
    • JavaScript怎么找出数组中的重复或非重复元素
      本文小编为大家详细介绍“JavaScript怎么找出数组中的重复或非重复元素”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript怎么找出数组中的重复或非重复元素”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习...
      99+
      2023-06-29
    • LeetCode中怎么输出数组中重复的数字
      LeetCode中怎么输出数组中重复的数字,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。题目:数组中重复的数字在一个长度为 n 的数组 n...
      99+
      2022-10-19
    • sql怎么找出重复的数据
      要找出重复的数据,可以使用SQL语句中的GROUP BY和HAVING子句。 下面是一个示例,假设有一个名为employee...
      99+
      2023-10-22
      sql
    • php中怎么找出数组中重复率最高的值
      php中怎么找出数组中重复率最高的值,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。我们来看看下面一个例子。<phpheader("Content...
      99+
      2023-06-20
    • 怎么使用Python pandas找出删除重复的数据
      这篇文章主要介绍了怎么使用Python pandas找出删除重复的数据的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python pandas找出删除重复的数据文章都会有所收获,下面...
      99+
      2023-07-02
    • 4个数字组成不重复的3位数python脚
      4个数字组成不重复的3位数python脚本: 注:1、range(1,5),1-4不包括52、if and判断3、变量中间用“,”隔开,输出时中间为空格 #!/usr/bin/python for i in range(1,5):for...
      99+
      2023-01-31
      位数 数字 python
    • Oracle修改字符集前怎么找出可能出现问题的数据
      本篇内容主要讲解“Oracle修改字符集前怎么找出可能出现问题的数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle修改字符集前怎么找出可能出现问题的...
      99+
      2022-10-18
    • python怎么找出只出现一次的数字
      可以通过使用Counter函数来统计数字出现的次数,然后遍历统计结果,找出出现次数为1的数字。以下是一个示例代码:```python...
      99+
      2023-09-29
      python
    • Java/Python怎么找出无重复字符的最长子串
      这篇文章主要讲解了“Java/Python怎么找出无重复字符的最长子串”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java/Python怎么找出无重复字符的最长子串”吧!题目:给定一个字符...
      99+
      2023-06-02
    • python怎么找出列表中相同的数字
      要找出列表中相同的数字,可以使用循环和条件判断来比较列表中的每个元素。以下是一个示例代码,演示如何找出列表中相同的数字:```pyt...
      99+
      2023-09-26
      python
    • php怎么查找和删除数组中的重复数据
      在Web开发中,经常会遇到需要对大量数据进行查找和操作的情况,例如从数据库中查询某些特定记录或者对数据进行删除操作。在这样的情景下,PHP作为一种广泛应用的Web开发语言,其内置的函数和库往往可以方便地完成这些任务。本文将介绍如何使用PHP...
      99+
      2023-05-14
      php php数组
    • php怎么实现踢出数组的重复值
      在开发过程中,经常会涉及到处理数组的场景,其中处理重复值的问题是较为常见的。比如在购物车中,当用户加入同一种商品时需要判断商品是否已存在,避免重复添加。在这些场景下,我们需要一种方法来去除重复值,保证数据的准确性。PHP作为一种常用的服务器...
      99+
      2023-05-14
    • java怎么消除数组中重复出现的值
      可以使用Set来消除数组中重复出现的值。Set是一个不允许有重复元素的集合,可以用来存储数组中的元素,然后再将Set转换回数组。以下...
      99+
      2023-10-20
      java
    • php怎么提取数组中不重复的值
      提取步骤:1、利用array_count_values()函数统计数组中元素的出现次数,语法“array_count_values(原数组)”,会返回一个关联数组,其元素的键名是原数组的值,键值是该值在原数组中出现的次数;2、利用array...
      99+
      2022-07-13
      php php数组
    • 怎么用Python找出文本中每个字母出现的次数
      这篇文章主要介绍“怎么用Python找出文本中每个字母出现的次数”,在日常操作中,相信很多人在怎么用Python找出文本中每个字母出现的次数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python找出...
      99+
      2023-06-04
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作