题目描述:找出数组中重复的数字,具体内容如下

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

这个面试题是剑指offer中的面试题3,,下面我用java代码实现。

算法步骤:

从头到尾依次扫描数组中的每个数字。

1. 当扫描到下表为i的数字时,首先比较这个数字(用m表示)是不是等于下标i;

2. 如果是,则接着扫描下一个数字;如果不是,则再拿它和第m个数字进行比较。

3. 如果它和第m个数字相等,就找到了一个重复的数字(也就是下标 i 和下标 m 的位置都出现了)

4. 如果它和第m个位置数字不相等,就把第i个数字和第 m 个数字交换。

5. 接下来我们再重复这个比较、交换的过程,知道我们发现一个重复的数字。

import java.util.Scanner;

public class Main {

public static void getRepeateNum( int[] num) {

int NumChange;

System.out.println("重复数字是:");

for(int index = 0; index < num.length; index++) {

while(num[index] != index) {

if(num[index] == num[num[index]]) {

System.out.print(num[index]+" ");

break;

} else {

NumChange = num[num[index]];

num[num[index]] = num[index];

num[index] = NumChange;

}

}

}

}

public static void main(String[] args) {

Scanner scanner = new Scanner(System.in);

int[] num = new int[5]; //数组长度可以自己定义

System.out.println("请输入一组数据:");

for(int i = 0; i < 5; i++) {

num[i] = scanner.nextInt();

}

getRepeateNum(num);

}

}

其实还可以使用java中的Map实现。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

java如何找重复数字_Java如何找出数组中重复的数字相关推荐

  1. java两个数组中不同的数字_java将两个数组中不同的数字去掉一个剩下的保存到一个新的数组中...

    展开全部 package co; import java.util.Arrays; import java.util.HashSet; import java.util.Set; /** * java ...

  2. 剑指offer 面试题三 找出数组中重复的数字

    1 import org.junit.Test; 2 3 import java.util.Arrays; 4 import java.util.HashSet; 5 6 public class D ...

  3. 图解面试题:找出数组中重复的数字?

    今天分享的题目来源于 LeetCode 上的剑指 Offer 系列 面试题03. 数组中重复的数字. 题目链接:https://leetcode-cn.com/problems/shu-zu-zhon ...

  4. 找出数组中重复的数字---多思路

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

  5. 找出重复的数java_剑指offer:1.找出数组中重复的数(java版)

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

  6. 13. 找出数组中重复的数字【难度: 简单 / 知识点: 模拟】

    13. 找出数组中重复的数字[难度: 简单 / 知识点: 模拟] 方法一: map 计数 时间复杂度O(nlongn) 空间复杂度多了一个二叉树 class Solution {public:int ...

  7. 01、找出数组中重复的数字

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

  8. JS实现找出数组中重复的数字的三种方法

    分享在JS中实现--找出数组中重复数字的方法的三种 法一. 排序比较法 先排序,再通过遍历比较,若相等,则添加到结果数组中,最后对结果数组进行去重,即可得到结果. function getSameNu ...

  9. 剑指offer 有人相爱,有人夜里开车看海,有人leetcode第一题都做不出来(leetcode有空就刷系列之找出数组中重复的数字)

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

最新文章

  1. 影像组学视频学习笔记(25)-查看准确度、灵敏度、特异度及混淆矩阵、Li‘s have a solution and plan.
  2. matlab 直方图_MATLAB作图实例:19:用二元直方图分析图片颜色
  3. 即时通讯音视频开发(一):视频编解码之理论概述
  4. angularJs中ngModel的坑
  5. 其它综合-CentOS7 忘记root密码
  6. matchers依赖_Hamcrest Matchers教程
  7. 数据挖掘——相似文章推荐
  8. ​【月报】Java知音的三月汇总
  9. php中NULL、false、0、 有何区别?
  10. SQL Server系统数据库– msdb数据库
  11. [转]《帮我买个单》
  12. PS入门教程之字体的变形艺术
  13. Git和Github的基本操作
  14. android显示动态图片,android显示gif图
  15. NCCL下载及安装教程
  16. java后端开发(九):mybatis的威力加强版之mybatis-plus
  17. android10全面屏手势 操作图,丨系统设计丨ZUI 10加入更多全面屏手势
  18. 求水仙花数C语言实现
  19. 饿了么“核心交易系统”微服务化5年演化史!20页ppt,万字长文干货!
  20. XTU数据结构(C语言版)

热门文章

  1. UTF-8、GB2312、GB18030、GBK和BIG5等字符集编码范围的具体说明
  2. 多线程之间共享的资源有哪些
  3. Google C++单元测试框架(Gtest)系列教程之一——入门
  4. 喷喷计算机语言掌握的程度
  5. iservice封装有哪些方法_5w大功率led白光灯珠参数,5w大功率led灯珠有哪些?
  6. linux 安装wdcp控制面板
  7. 产品经理思维模型:怎么理解MVP、PMF
  8. Android检测是否有悬浮窗,Android 获取判断是否有悬浮窗权限的方法
  9. 三态门三个状态vhdl_温故知新,高阻态和三态门
  10. 拿着5家offer的Java,对面试官做了什么?