码迷,mamicode.com
首页 > 编程语言 > 详细

面试题 一个长度为100的数组,随机插入1-100,不重复,写出大致思路即可;

时间:2016-09-20 01:36:02      阅读:696      评论:0      收藏:0      [点我收藏+]

标签:

之前回答的是:

  定义一个长度为100的a数组,存1-100,每次从数组里随机的位置取一个元素,放入b数组,并且从a数组移除;

 

后来百度了一下,说是数组重新排列不够好,更好的做法是 每次将随机取到的数与数组 "最后一位" 交换;

想想还是有点道理,不用重新排列,而且不需要两个数组

<script>

    function fn(n) {
        var arr = [];
        for (var i = 0; i < n + 1; i++) {
            arr[i] = i + 1;
        }
        for (var i = 0; i < n; i++) {
            var random = Math.floor(Math.random() * (n - i));
            arr[n] = arr[n - 1 - i];
            arr[n - 1 - i] = arr[random];
            arr[random] = arr[n];
        }
        return arr.slice(0, n);
    }

    fn(100).forEach(function (m) { console.log(m); });
</script>

 

面试题 一个长度为100的数组,随机插入1-100,不重复,写出大致思路即可;

标签:

原文地址:http://www.cnblogs.com/xiaoyaxiaopingguo/p/5887280.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!