第一天
- 题目来源:前端每日知识3+1
Javascript题目
题目:用
递归算法实现,数组长度为5且元素的随机数在2-32间不重复的值
问题解答
解题思路
- 生成一个长度为5的空数组arr。
- 生成一个(2-32)之间的随机整数rand。
- 把随机数rand插入到数组arr内,如果数组arr内已存在与rand相同的数字,则重新生成随机数rand并插入到arr内
需要使用递归实现,不能使用for/while等循环 - 最终输出一个长度为5,且内容不重复的数组arr。
include方法
- 构造方法
function insertArr(arr, i = 0, min = 2, max = 32) {// const num = Math.max(min, Math.ceil(Math.random() * max))let num = Math.floor(Math.random() * (max-min+1) + min)if (!arr[arr.length - 1]) {if (!arr.includes(num)) {arr[i++] = num}return insertArr(arr, i)}return arr}const arr = new Array(5);const result = insertArr(arr)console.log(arr);
- 一般方法
let arr = []function insertArr(arr, min = 2, max = 32) {let num = Math.floor(Math.random() * (max-min+1) + min)if (arr.length<5) {if (!arr.includes(num)) {arr.push(num)}return insertArr(arr)}return arr}insertArr(arr)console.log(arr);
indexOf方法
let arr = []function foo(arr,max=32,min=2) {if (arr.length >= 5) {return arr}let n = Math.floor(Math.random() * (max-min+1) + min)if (arr.indexOf(n) == -1) {arr.push(n)}return foo(arr)}foo(arr)
