zoukankan      html  css  js  c++  java
  • 算法题:1、数组中重复的数字

    题目描述

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

    Input: {2, 3, 1, 0, 2, 5} 
    Output: 2
    

    解题思路

    对于这种数组元素在 [0, n-1] 范围内的问题,可以将值为 i 的元素调整到第 i 个位置上进行求解。
    以 (2, 3, 1, 0, 2, 5) 为例,遍历到位置 4 时,该位置上的数为 2,但是第 2 个位置上已经有一个 2 的值了,因此可以知道 2 重复。

    代码

    //nums为传入数组,length是数组长度,duplication是重复的值
    public boolean duplicate(int[] nums, int length, int[] duplication) {
        //检查边界条件
        if (nums == null || length <= 0) {
            return false;
        }
        for (int i = 0; i < length; i++) {
            //当nums[i]没有放到i位置时,要将nums[i]移动到nums[nums[i]]位置。此时如果num[nums[i]]上的位置与nums[i]相同则重复并返回,如果一直没有重复返回false。
            //因为这里将后面的数交换了过来所以需要用while
            while (nums[i] != i) {
                if (nums[i] == nums[nums[i]]) {
                    duplication[0] = nums[i];
                    return true;
                }
                swap(nums, i, nums[i]);
            }
        }
        return false;
    }
    
    private void swap(int[] nums, int i, int j) {
            int t = nums[i];
            nums[i] = nums[j];
            nums[j] = t;
    }
    
  • 相关阅读:
    go语言切片
    sharding-jdbc分库分表配置,多数据源
    spring boot的配置文件
    go-micro生成项目
    自定义注解+aop实现jetcache功能扩展
    linux下mysql忘记密码解决方案
    MySQL 1130错误,无法远程连接
    Linux/UNIX 上安装 MySQL
    BarTender遇到的问题
    SourceTree安装使用
  • 原文地址:https://www.cnblogs.com/fcb-it/p/12805971.html
Copyright © 2011-2022 走看看