博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java 高级算法——数组中查询重复的数字
阅读量:6570 次
发布时间:2019-06-24

本文共 404 字,大约阅读时间需要 1 分钟。

题目一:找到数组中重复的数字。

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

解决方法一:将这个数组排序,从排序的数组中找到重复的数字是一件很容易的事情。只需要从头到尾扫描排序后的数组就可以了,排序一个长度为N的数组需要O(nLogn)的时间。

解决方法二:利用哈希表来解决,从头到尾扫描数组的每一个数字,每次扫描到一个数字的时候,就判断是否在哈希表中是否有这个数字,这个算法的时间是O(N),但它的时间效率是一个大小为O(N)的哈希表为代价的。

解决方法三:我们重排这个数组,从头到尾依次扫描这个数组中的每一个数字,当扫描到下标为i的数字的时候,就比较这个数字的值(m)是不是等于i,如果相等,则将m的值付给i,如果不相等,则拿他和m下标对应的值比较,直到找到所有重复的数值为止。

clipboard.png

转载地址:http://ufvjo.baihongyu.com/

你可能感兴趣的文章
关于在线代码运行网站的一个想法
查看>>
我的友情链接
查看>>
使用subeclipse来管理分支/标记
查看>>
我的友情链接
查看>>
django forms模块使用
查看>>
FreeBSD IPFW 防火墙的安装和设置
查看>>
Linux分区和文件系统 ⑥
查看>>
ClipDrawable--水漫起来的效果
查看>>
osd内的pg数量
查看>>
shell脚本与mysql交互方法汇总
查看>>
Cron 表达式详解和案例
查看>>
Android - 软件自动更新的实现
查看>>
oracle数据库远程不落地导入本地数据库
查看>>
dns相关内容
查看>>
JavaScript骚操作
查看>>
MySQL的主从复制与读写分离原理
查看>>
luaCPU性能测试
查看>>
mysql优化
查看>>
【批处理】for循环中产生不同的随机数
查看>>
Gradle -help
查看>>