每日一题《剑指offer》数组篇之数组中重复的数字

今日题目链接:数组中重复的数字

数组中重复的数字

难度:简单

描述

在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组[2,3,1,0,2,5,3],那么对应的输出是2或者3。存在不合法的输入的话输出-1

数据范围

数据范围:0 0≤n≤10000

进阶:时间复杂度O(n) ,空间复杂度O(n)

举例

解题思路

方法一:利用HashMap来记录每个数字出现的次数,key为数组中的数字,value为出现的次数,遍历一遍数组,每次利用ContainsKey的true或者false来进行判断,如果为true说明map中已经存在这样的数字了,便将其value+1;如果为false说明是第一次出现这样的数字直接将其put进map中value为1

方法二:数据重排,重头到尾扫描数组S中的每一个元素,当扫描到第i个元素的时候,比较第i个元素位置的值m是否等于i,如果相等,则说明该元素已经在排好序的位置,继续扫描其他元素;如果不相等,先判断m是否等于S[m],相等则说明不同位置上的元素值相等,即元素重复。直接返回元素;否则交换m和S[m]将他们放置到排好序的位置

实现代码(java)

方法一:

java 复制代码
import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param numbers int整型一维数组 
     * @return int整型
     */
    public int duplicate (int[] numbers) {
        // write code here
        HashMap<Integer,Integer> map = new HashMap<Integer,Integer>();
        for(int i = 0; i < numbers.length;i++){
            if(map.containsKey(numbers[i])){//如果为true,则将value+1
                map.replace(numbers[i],map.get(numbers[i]),map.get(numbers[i])+1);
            }else{//为false,则将value设为1
                map.put(numbers[i],1);
            }
        }
        //遍历一遍map,如果value不为1直接return出去,如果都没有直接return -1
        for(Map.Entry<Integer,Integer> entry:map.entrySet()){
            if(entry.getValue()!=1){
                return entry.getKey();
            }
        }

        return -1;
    }
}

方法二:

arduino 复制代码
int duplicate(vector<int>& numbers) {
    int i=0,n=numbers.size();
    while(i<n){
        if(numbers[i] == i){    //第i个位置的元素就是i
            i++;
            continue;
        }else{
            if(numbers[i] == numbers[numbers[i]])   //不同位置上出现了相同的元素,即元素重复
                return numbers[i];
            else
                swap(numbers[i],numbers[numbers[i]]);   //交换元素到对应的位置
        }
    }
    return -1;
}
相关推荐
涡能增压发动积17 小时前
同样的代码循环 10次正常 循环 100次就抛异常?自定义 Comparator 的 bug 让我丢尽颜面
后端
Wenweno0o17 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
小O的算法实验室17 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
于慨17 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz17 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
swg32132117 小时前
Spring Boot 3.X Oauth2 认证服务与资源服务
java·spring boot·后端
从前慢丶17 小时前
前端交互规范(Web 端)
前端
tyung17 小时前
一个 main.go 搞定协作白板:你画一笔,全世界都看见
后端·go
gelald17 小时前
SpringBoot - 自动配置原理
java·spring boot·后端
CHU72903517 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序