【每天学一点 - 算法篇 - 设计技巧 - 随机化算法】

系列文章目录

【每天学一点 - 算法篇 - 设计技巧 - 贪婪算法】
【每天学一点 - 算法篇 - 设计技巧 - 分治算法】
【每天学一点 - 算法篇 - 设计技巧 - 动态规划】



前言

工作,生活,学习,哎,世事无常,大常包小常。


一、什么是随机化算法

随机化算法其实不太算解决问题的技巧,
而是更倾向于在说如何生成随机数这件事,
或者至少是伪随机数。
伪随机的话,用当前时间是一个不错的想法,
但是如果在较短的时间内连续生成大量的话,
还是会有一定的规律性,
再有就是

线性同余数发生器
Xi+1=A Xi mod M

其实java生成随机数还有一个更简单的选择,
那就是randam函数


二、随机化算法原理

1、示例

给你一个整数数组 nums ,设计算法来打乱一个没有重复元素的数组。打乱后,数组的所有排列应该是 等可能 的。
实现 Solution class:
Solution(int[] nums) 使用整数数组 nums 初始化对象
int[] reset() 重设数组到它的初始状态并返回
int[] shuffle() 返回数组随机打乱后的结果
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/shuffle-an-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2、思路

其实关键解题点就在于如何把一个数放到一个新的随机位置,
我试图使用位置的hash值和当前时间的hash值取异或来确定随机位置,
但这种方式在力扣的大量重复操作下,并没有认可,
最后还是使用了java自带的randam函数

3、抽象


    int[] nums;
    public void solution(int[] nums) {
        this.nums = nums;
    }

    public int[] reset() {
        return nums;
    }

    public int[] shuffle()  {
        int[] random = new int[nums.length];
        for (int num : nums) {
            int pos =(int) (Math.random()*nums.length);
            if (pos < 0) {
                pos = Math.abs(pos);
            }
            while (random[pos] != 0) {
                    pos = (int) (Math.random()*nums.length);

            }
            random[pos] = num;
        }
        return random;
    }



总结

生活不易,烦躁,烦躁,烦躁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

破晓星芒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值