博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
find-all-duplicates-in-an-array(典型的数组中的重复数,不错,我做出来了,可是发现别人有更好的做法)...
阅读量:6831 次
发布时间:2019-06-26

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

https://leetcode.com/problems/find-all-duplicates-in-an-array/

典型的数组中的重复数。这次是通过跳转法,一个个跳转排查的。因为查过的不会重复处理,所以复杂度也是O(n)。

 

后面发现了别人一个更好的做法。。。如下:

public class Solution {    // when find a number i, flip the number at position i-1 to negative.     // if the number at position i-1 is already negative, i is the number that occurs twice.        public List
findDuplicates(int[] nums) { List
res = new ArrayList<>(); for (int i = 0; i < nums.length; ++i) { int index = Math.abs(nums[i])-1; if (nums[index] < 0) res.add(Math.abs(index+1)); nums[index] = -nums[index]; } return res; }}

 

我的做法:

package com.company;import java.util.ArrayList;import java.util.Iterator;import java.util.List;class Solution {    public List
findDuplicates(int[] nums) { List
list = new ArrayList<>(); int index = 1; while (index <= nums.length) { int next = nums[index-1]; nums[index-1] = -1; while (next != -1 && next != index && -1 != nums[next-1] && next != nums[next-1]) { int tmp = nums[next-1]; nums[next-1] = next; next = tmp; } if (next == -1) { } if (next == index) { nums[index-1] = next; } else if (-1 == nums[next-1]) { nums[next-1] = next; } else { list.add(next); } index++; } return list; }}public class Main { public static void main(String[] args) { System.out.println("Hello!"); Solution solution = new Solution(); int[] nums = {}; List
ret = solution.findDuplicates(nums); System.out.printf("ret len is %d\n", ret.size()); Iterator iter = ret.iterator(); while (iter.hasNext()) { System.out.printf("%d,", iter.next()); } System.out.println(); }}

 

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

你可能感兴趣的文章
在web.config中配置httpHandlers节点是的说明
查看>>
c++:数据类型的推断type_traits
查看>>
Python——异常基础
查看>>
UVa 112 树求和
查看>>
物理结构与逻辑结构
查看>>
hdoj-1312-Red and Black
查看>>
VB.NET机房收费系统总结
查看>>
MIDL相关
查看>>
ocx控件针对网页刷新和关闭分别进行区分处理
查看>>
CSS3:box-sizing:不再为盒子模型而烦恼
查看>>
Ubuntu 16.04下UML建模PowerDesigner的替代ERMaster和MySQL Workbench
查看>>
Storm工作流程
查看>>
分布式架构设计之电商平台
查看>>
java编程思想——java IO系统
查看>>
SpringBootApplication注解 专题
查看>>
socket服务器的搭建-Mac(转)
查看>>
Opencv探索之路(十九):读写xml和yml文件
查看>>
Eclipse插件开发中的选择监听机制(Selection Provider-Listener)
查看>>
14.并发与异步 - 2.任务Task -《果壳中的c#》
查看>>
Linux时间子系统之三:jiffies
查看>>