-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy path384.shuffle-an-array.java
80 lines (72 loc) · 1.74 KB
/
384.shuffle-an-array.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
* @lc app=leetcode id=384 lang=java
*
* [384] Shuffle an Array
*
* https://leetcode.com/problems/shuffle-an-array/description/
*
* algorithms
* Medium (49.48%)
* Total Accepted: 73.5K
* Total Submissions: 147.4K
* Testcase Example: '["Solution","shuffle","reset","shuffle"]\n[[[1,2,3]],[],[],[]]'
*
* Shuffle a set of numbers without duplicates.
*
*
* Example:
*
* // Init an array with set 1, 2, and 3.
* int[] nums = {1,2,3};
* Solution solution = new Solution(nums);
*
* // Shuffle the array [1,2,3] and return its result. Any permutation of
* [1,2,3] must equally likely to be returned.
* solution.shuffle();
*
* // Resets the array back to its original configuration [1,2,3].
* solution.reset();
*
* // Returns the random shuffling of array [1,2,3].
* solution.shuffle();
*
*
*/
class Solution {
int[] array;
int[] original;
Random random = new Random();
public Solution(int[] nums) {
array = nums;
original = nums.clone();
}
/** Resets the array to its original configuration and return it. */
public int[] reset() {
array = original;
original = original.clone();
return original;
}
/** Returns a random shuffling of the array. */
public int[] shuffle() {
int len = array.length;
for (int i = 0; i < len; i++) {
swap(array, i, rand(i, len));
}
return array;
}
public int rand(int min, int max) {
return random.nextInt(max - min) + min;
}
public void swap(int[] nums, int i, int j) {
if (i == j) return;
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
}
/**
* Your Solution object will be instantiated and called as such:
* Solution obj = new Solution(nums);
* int[] param_1 = obj.reset();
* int[] param_2 = obj.shuffle();
*/