javascript - js完全打乱数组
问题描述
var arr = [0,1,2,3,4,5,6,7]
完全打乱,要求,每个元素的位置必须要变动
问题解答
回答1:首先,题主并不是要传统的数组乱序,如果是传统的数组乱序,当然首推 Fisher-Yates,Math.random() 的黑科技并不能保证概率的一致,详情可以看我以前的分析 https://github.com/hanzichi/u...
如果每个位置都需要变动,随便写了一段代码,勉强可以用:
function shuffle(a) { let len = a.length; let shuffled = Array(len); for (let i = len; i--; ) { let rand = ~~(Math.random() * i); shuffled[i] = a[rand]; a[rand] = a[i]; } return shuffled;}
新建了一个数组,并且污染了原数组,很不优雅,题主可以自己改进下
回答2:把最后一个放第一个就实现了每个元素都动了,可是完全打乱是什么意思?
var arr = [0,1,2,3,4,5,6,7], last = arr[arr.length - 1];arr.splice(arr.length - 1, 1);arr.unshift(last) 回答3:
随机是不可能保证每个位置都变动的。
要彻底打乱,就不能保证位置都变。
笨一点的方法就是打乱一次,再跟数组做比较,直到符合条件为止。
回答4:刚没看清 , 这个可以吗?function upset(arr){ let newArr = arr.slice().sort(() => Math.random()>0.5 ? 1 : -1) let result = arr.some((item,index)=>{ return item === newArr[index] }) if(!result){ return newArr }else{ return upset(newArr) }}回答5:
function compare(a , b){Math.random > 0.5 ? return -1 ; return 1 } arr.sort(compare); 回答6:
function shuffle (arr) {
var _floor = Math.floor,_random = Math.random,len = arr.length; for(var i = 0; i < len - 1; ++i){var rand_pos = _floor(_random() * (len - i)) + i;if(rand_pos != i){ var tmp = arr[i]; arr[i] = arr[rand_pos]; arr[rand_pos] = tmp;} } return arr;};回答7:
随机平移,凯撒加密红红火火……
function shuffle (arr) { if (!Array.isArray(arr)) { return [] } var len = Math.floor(Math.random() * (arr.length - 1)) + 1 return arr.slice(len).concat(arr.slice(0, len))}回答8:
最简单的位置全都动
> arr = [0,1,2,3,4,5,6,7]> arr.unshift(arr.pop())> arr[ 7, 0, 1, 2, 3, 4, 5, 6 ]> arr.sort((a , b)=>Math.random() > 0.5 ? -1:1)[ 6, 5, 4, 0, 1, 3, 7, 2 ]> arr.sort((a , b)=>Math.random() > 0.5 ? -1:1)[ 6, 0, 5, 3, 4, 7, 1, 2 ]
位置全都动其实并不是最乱的;
最乱的应该是随机洗牌,有一定概率保持某个数不动,这样才没规律可循。
相关文章:
1. javascript - vue 数据更新了。但是dom没有更新,,,,,如图2. javascript - 静态页面引公共头尾文件,js怎么写吖?3. javascript - 读取页面源码,页面中所有的换行都被当成<br/>读取出来 了,,求解应该怎么让它被正确的解析4. java - 为什么要将Runnable接口的子类对象传递给Thread的构造函数?5. java - 3个dao的数据根据请求参数选择一个映射到一个url上,怎么写比较好?6. docker api 开发的端口怎么获取?7. java基础,求解答。8. html5 - 百度Ueditor代码高亮和代码段滚动条冲突是怎么回事?9. debian - docker依赖的aufs-tools源码哪里可以找到啊?10. javascript - 关于一段 for 循环代码执行顺序的问题