384. Shuffle an Array

网友投稿 240 2022-11-15

384. Shuffle an Array

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 { private int[] original; private Random rng = new Random(); private int[] copy; private int num; public Solution(int[] nums) { original = nums; copy=original.clone(); num=original.length; } /** Resets the array to its original configuration and return it. */ public int[] reset() { return original; } /** Returns a random shuffling of the array. */ public int[] shuffle() { int n = num; while(n>1) { n--; int k = rng.nextInt(n + 1); int value = copy[k]; copy[k] = copy[n]; copy[n] = value; } return copy; }}/** * 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(); */

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:全网最新Log4j 漏洞修复和临时补救方法
下一篇:92. Reverse Linked List II
相关文章

 发表评论

暂时没有评论,来抢沙发吧~