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;
    }
    
  • 相关阅读:
    laravel-13-笔记-1
    laravel-14-笔记-2
    supervisor监听器-linux安装配置
    laravel-12-artisan命令创建view文件
    linux修改主机名
    laravel-11-laravel 模型Eloquent ORM
    laravel-composer安装laravel
    laravel-10-laravel collection集合
    laravel-8-laravel数据填充
    laravel-9-laravel数据库查询 查询组件
  • 原文地址:https://www.cnblogs.com/fcb-it/p/12805971.html
Copyright © 2011-2022 走看看