来源 | 小夕学算法
Java
public int findRepeatNumber(int[] nums) {
Set set = new HashSet();
for (int num : nums) {
if (!set.add(num))
return num;
}
return -1;
}
C++
class Solution {
public:
int findRepeatNumber(vector& nums) {
unordered_map map;
for(int num : nums) {
if(map[num]) return num;
map[num] = true;
}
return -1;
}
};
JS
/**
* @param {number[]} nums
* @return {number}
*/
var findRepeatNumber = function(nums) {
let s=new Set();
for(var i in nums){
var Length=s.size;
s.add(nums[i]);
if(s.size==Length)
return nums[i];
}
};
Python
class Solution(object):
def findRepeatNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
dic = {}
for i in nums:
if i not in dic:
dic[i] = 0
else:
return i
data:image/s3,"s3://crabby-images/ba9e1/ba9e17978e29d4070929e030d87694b416be7311" alt=""
data:image/s3,"s3://crabby-images/9afe4/9afe4a71aa0eda3026e64d17aae2114e7145df23" alt=""
data:image/s3,"s3://crabby-images/2b70d/2b70dd5b06f9d1c1b1366a4b4c6fb36bc406cd02" alt=""
新题目:
题目思路
-
数组中的元素值是 2、1、3、0、4
,同时数组的索引下标是0、1、2、3、4
。 -
可以发现数组的元素的索引和数组值存在一一对应的关系。 -
因此可以通过遍历数组,比如某第一个元素值2索引是0,我们做一个交换,就把它放到nums[2]中(也就是到把第一个元素值2放到了索引是2的地方,即nums[current] = current),这样把数组的值和索引一一对应起来。
新题目图解思路
data:image/s3,"s3://crabby-images/a7c17/a7c174201a09d3862c985c0cba47ad873c52eae6" alt=""
data:image/s3,"s3://crabby-images/15940/159404494a00126c716067008870adb7511693c1" alt=""
data:image/s3,"s3://crabby-images/ddd79/ddd798cb302af53897f140191772f83cff994c22" alt=""
data:image/s3,"s3://crabby-images/b5ffe/b5ffe696d4974580de29e8bf8896fe529227dff6" alt=""
data:image/s3,"s3://crabby-images/1823c/1823c6718c6081ba867a7cd21600576d82817f64" alt=""
data:image/s3,"s3://crabby-images/3c60d/3c60d7cba3159a6918abd5653511b1f501405628" alt=""
data:image/s3,"s3://crabby-images/d63b5/d63b5815708c91e5fa903cbdaceb66aabcc0eacb" alt=""
data:image/s3,"s3://crabby-images/6f449/6f449d0d6d710d7df056fa9001a0da339ac0a479" alt=""
data:image/s3,"s3://crabby-images/f1ca1/f1ca130092c2fede5efd02f70e796949fca2fc50" alt=""
data:image/s3,"s3://crabby-images/66e7b/66e7b0e48620c4c82c6420eebd290f058daa223b" alt=""
data:image/s3,"s3://crabby-images/0685f/0685f0645cc403ad637f64befe18affb588bd533" alt=""
data:image/s3,"s3://crabby-images/51109/5110962d6e13d11ed343625d7e2699468cbd4a8d" alt=""
新题目复杂度
data:image/s3,"s3://crabby-images/33e90/33e9029a9198944cb9179130bb43d57d8f2f82b6" alt=""
data:image/s3,"s3://crabby-images/1e515/1e51512c80297542dff85414cebff28236efe26a" alt=""
data:image/s3,"s3://crabby-images/0ef12/0ef12d1c3c9ed28360bff0900e64084d7800ddaa" alt=""
data:image/s3,"s3://crabby-images/06913/06913b00cd29b89acb7212358692a9a513b64fa3" alt=""
data:image/s3,"s3://crabby-images/14386/14386097c13c5db8f4dc000dce71f3c899b38913" alt=""
data:image/s3,"s3://crabby-images/27601/2760125143ad6fd7124354dfc3a66d8be81dfd6c" alt=""
data:image/s3,"s3://crabby-images/4a2de/4a2de79b4898cf8fba04eb1bdf4a8ec0325ecf81" alt=""
data:image/s3,"s3://crabby-images/21ea7/21ea72c299f50c09cecfc8e957c8cd6cb7d85f54" alt=""
data:image/s3,"s3://crabby-images/73f87/73f87b4d3e68eb1e7d55ed593efc4cbec1dbef8a" alt=""
data:image/s3,"s3://crabby-images/7f36d/7f36ddb2a3a146ddf7f70c4e05f0832496869948" alt=""
data:image/s3,"s3://crabby-images/72da8/72da89b0c3240e6613c762ea31a737823093dfac" alt=""
data:image/s3,"s3://crabby-images/7de3a/7de3ac4592051baeb52429ca231e6f9c5ac29e43" alt=""
data:image/s3,"s3://crabby-images/723f6/723f675787e3c444cca840662cf58a49bdd73632" alt=""
data:image/s3,"s3://crabby-images/9ae65/9ae65040fd12c37f2c1db8e166feac6e555bee88" alt=""
data:image/s3,"s3://crabby-images/79cb4/79cb430cd48817f07c48887eef45b23cb48ffe70" alt=""
data:image/s3,"s3://crabby-images/1c0cb/1c0cb9e1bfc46909328288a5d79a8c8e7f6f5f9c" alt=""
data:image/s3,"s3://crabby-images/d97a5/d97a57971da82a7530fb8d42dea9f98de30e59e6" alt=""
data:image/s3,"s3://crabby-images/1c810/1c810f63642dc4f0d4a19785041ce4fc3d4bf1a3" alt=""
动画视频
代码实现
Java
class Solution {
public int findRepeatNumber(int[] nums) {
for(int current = 0;current < nums.length;) {
if (nums[current] == current) {
current++;
} else {
// 当前index = current下标值nums[current]和 index = nums[current] 的下标值 nums[nums[current]]相等
if(nums[current] == nums[nums[current]]) {
return nums[current];
} else {
swapTwoNumberInArray(nums, current, nums[current]);
}
}
}
return -1; // 没找到
}
public void swapTwoNumberInArray(int[] nums, int current, int another) {
int temp = nums[current];
nums[current] = nums[another];
nums[another] = temp;
}
}
C++
class Solution {
public:
int findRepeatNumber(vector& nums) {
for(int i = 0; i {
while(nums[i] != i) //当前元素不等于下标
{
if(nums[i] == nums[nums[i]]) return nums[i];
swap(nums[i],nums[nums[i]]);
}
}
return -1;
}
};
Python
class Solution(object):
def findRepeatNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
for i in range(len(nums)):
while nums[i] != i:
if nums[nums[i]] == nums[i]:
return nums[i]
nums[nums[i]] , nums[i] = nums[i] , nums[nums[i]] # 交换
return None
JS
var findRepeatNumber = function(nums) {
const length = nums.length;
for (let i = 0; i // 检测下标为i的元素是否放在了位置i上
while ((num = nums[i]) !== i) {
if (num === nums[num]) {
return num;
}
[nums[i], nums[num]] = [nums[num], nums[i]]; // 交换
}
}
};
data:image/s3,"s3://crabby-images/fdfb3/fdfb37969f71aa9ba8fcc24eaa1ed84502e668a3" alt=""
data:image/s3,"s3://crabby-images/b3007/b3007feee78d5d8d3292c0fc9cb3a540cade43ce" alt=""
小夕的牛客网Java代码
public class Solution {
// Parameters:
// numbers: an array of integers
// length: the length of array numbers
// duplication: (Output) the duplicated number in the array number,length of duplication array is 1,so using duplication[0] = ? in implementation;
// Here duplication like pointor in C/C++, duplication[0] equal *duplication in C/C++
// 这里要特别注意~返回任意重复的一个,赋值duplication[0]
// Return value: true if the input is valid, and there are some duplications in the array number
// otherwise false
public boolean duplicate(int numbers[],int length,int [] duplication) {
if(numbers == null) {
return false;
}
if(findRepeatNumber(numbers) != -1){
duplication[0] = findRepeatNumber(numbers);
return true;
}
return false;
}
public int findRepeatNumber(int[] nums) {
for(int current = 0;current < nums.length;) {
// num[current] = current 说明归位了 也就是成为了有序数组,那么继续往下遍历。
if (nums[current] == current) {
current++;
} else {
// 当前index = current下标值nums[current]和 index = nums[current] 的下标值 nums[nums[current]]相等
// 找到重复数字了
if(nums[current] == nums[nums[current]]) {
return nums[current];
} else {
// 没找到重复数字 所以把这两个数组中的数进行交换
// 目的是为了让num[current] = current 这样就变成了有序数组
swapTwoNumberInArray(nums, current, nums[current]);
}
}
}
return -1; // 没找到
}
public void swapTwoNumberInArray(int[] nums, int current, int another) {
int temp = nums[current];
nums[current] = nums[another];
nums[another] = temp;
}
}
data:image/s3,"s3://crabby-images/ac531/ac53190fe0b7bc9220eb5899d170417d851254d0" alt=""
data:image/s3,"s3://crabby-images/eb781/eb781c3aa158cf26373e04b05fb30e81490ceaaa" alt=""
data:image/s3,"s3://crabby-images/1e07c/1e07c2277fe3423767205db105c38cd12e71a87c" alt=""
第一个数字的思路
-
还是复用之前的思路,把数字依次归位。 -
当找到重复的数字的时候,不直接返回,而是用set把所有的重复数字保留下来。 -
然后遍历数组,找到这些重复数字的下标,然后把下标最小的那个数字返回,就得到了第一个了。
第一个数字AC的牛客网Java代码
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
public class Solution {
// Parameters:
// numbers: an array of integers
// length: the length of array numbers
// duplication: (Output) the duplicated number in the array number,length of duplication array is 1,so using duplication[0] = ? in implementation;
// Here duplication like pointor in C/C++, duplication[0] equal *duplication in C/C++
// 这里要特别注意~返回任意重复的一个,赋值duplication[0]
// Return value: true if the input is valid, and there are some duplications in the array number
// otherwise false
public boolean duplicate(int numbers[],int length,int [] duplication) {
if(numbers == null) {
return false;
}
Set<Integer> repeatNumberSet = new HashSet<>();
Map<Integer, Integer> repeatNumberMap = new HashMap<>();
getMap(numbers, repeatNumberMap);
findRepeatNumber(numbers, repeatNumberSet);
if(repeatNumberSet.size() != 0){
duplication[0] = getFirstNumber(numbers, repeatNumberSet, repeatNumberMap );
return true;
}
return false;
}
public int findRepeatNumber(int[] nums, Set<Integer> repeatNumberSet) {
for(int current = 0;current < nums.length;) {
// num[current] = current 说明归位了 也就是成为了有序数组,那么继续往下遍历。
if (nums[current] == current) {
current++;
} else {
// 当前index = current下标值nums[current]和 index = nums[current] 的下标值 nums[nums[current]]相等
// 找到重复数字了
if(nums[current] == nums[nums[current]]) {
repeatNumberSet.add(nums[current]);
current++;
// return nums[current];
} else {
// 没找到重复数字 所以把这两个数组中的数进行交换
// 目的是为了让num[current] = current 这样就变成了有序数组
swapTwoNumberInArray(nums, current, nums[current]);
}
}
}
return -1; // 没找到
}
public void swapTwoNumberInArray(int[] nums, int current, int another) {
int temp = nums[current];
nums[current] = nums[another];
nums[another] = temp;
}
public void getMap(int[] nums, Map<Integer, Integer> repeatNumberMap) {
for(int i = 0;i < nums.length; i++) {
Set<Integer> keySet = repeatNumberMap.keySet();
if (keySet != null && keySet.contains(nums[i])) {
if (repeatNumberMap.get(nums[i]) > i) {
repeatNumberMap.put(nums[i],i);
}
} else {
repeatNumberMap.put(nums[i],i);
}
}
}
public int getFirstNumber(int[] nums, Set<Integer> repeatNumberSet, Map<Integer, Integer> repeatNumberMap) {
int minIndex = nums.length;
int min = -1;
for(Integer repeatNumber : repeatNumberSet ) {
if (repeatNumberMap.get(repeatNumber) < minIndex) {
minIndex = repeatNumberMap.get(repeatNumber);
min = repeatNumber;
}
}
return min;
}
}
data:image/s3,"s3://crabby-images/f8253/f8253c988d4caa15853caaeb4792653992fe4af8" alt=""
data:image/s3,"s3://crabby-images/0dc6d/0dc6da689e6784f97996a510de77e64c278028d6" alt=""
data:image/s3,"s3://crabby-images/b953e/b953e07d948886fb84a46a1bb0de0ea107739aa0" alt=""
data:image/s3,"s3://crabby-images/891e1/891e1d7a6750b0bb53695260f3ce749ad2e228c3" alt=""
data:image/s3,"s3://crabby-images/beb3e/beb3ea121331a9eb80e500ef8f148ae84f9d43f7" alt=""
data:image/s3,"s3://crabby-images/625fb/625fb0a44883897b38e0931d038ad27412a716fb" alt=""
data:image/s3,"s3://crabby-images/6d521/6d52191162c98b128e1e4092d5cb47fd2b0f334b" alt=""
data:image/s3,"s3://crabby-images/f8f50/f8f50636b0dbd8b009b6b6d25be2854aa914511b" alt=""
data:image/s3,"s3://crabby-images/92e72/92e72f46a6b56b795b8463b3d9491e254ffb2ec3" alt=""
[elementor-template id=”6632″]sdfa2121125
0 条评论