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

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

数组中重复的数字

难度:简单

描述

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

数据范围

数据范围:0 0≤n≤10000

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

举例

image.png

解题思路

方法一:利用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]将他们放置到排好序的位置

image.png

实现代码(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;
    }
}

方法二:


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;
}



相关文章
|
4月前
|
人工智能 运维 监控
2026 OpenClaw/Clawdbot技能生态解析:从部署到精通,打造企业级AI生产力中枢
在2026年AI Agent的赛道上,OpenClaw(原Clawdbot)已从单一的对话工具,进化为以“技能生态”为核心的开放式生产力平台。其核心竞争力不再局限于底层的对话能力,而是依托ClawHub技能市场中超过5700个的模块化技能,实现了从“能听会说”到“能做会管”的跨越式发展。然而,大量用户在部署后陷入“技能多而不精、配置繁而不会”的困境,要么因部署复杂放弃云端方案,要么因技能搭配不当导致效率不升反降。
962 10
|
6月前
|
人工智能 前端开发 测试技术
告别 GUI Agent 工程基建噩梦!阶跃星辰开源 4B 模型,本地轻松部署,玩转安卓应用
阶跃星辰开源GELab-Zero,首发4B GUI Agent模型及完整基建,支持一键部署,在多端性能达SOTA。同步推出真实场景评测基准AndroidDaily,推动GUI智能体规模化落地。
1108 10
告别 GUI Agent 工程基建噩梦!阶跃星辰开源 4B 模型,本地轻松部署,玩转安卓应用
|
2月前
|
SQL 人工智能 缓存
Claude Code自动模式上线:AI开始自己改代码了
Claude Code上线“自动模式”:AI获代码修改与文件写入权限,从“建议执行”升级为“直接执行”。这不仅是效率提升,更是开发权向AI转移的开端,重构输入方式、控制逻辑与开发者角色。测试、安全与边界管控成新焦点。
|
3月前
|
人工智能 数据挖掘 程序员
Claude Skills:如何将提示词升级为可复用技能
深入解析 Claude Skills 的核心原理、渐进披露架构和最佳实践,手把手教你创建自定义技能,实现从临时提示词到可复用资产的升级
677 1
|
人工智能 算法 Python
【随手记】python的heapq库的基本用法
【随手记】python的heapq库的基本用法
656 1
|
6月前
|
存储 算法 BI
xxljob本地运行
本文介绍XXL-JOB分布式任务调度的使用教程。包含源码获取、服务端部署(数据库导入、配置修改、启动访问)、客户端运行与执行器注册,以及调度任务配置和路由策略详解。通过实际操作演示任务创建、参数设置、手动执行与日志查看,帮助开发者快速掌握XXL-JOB核心功能,实现定时任务的可视化管理和高效调度。(238字)

热门文章

最新文章