【剑指Offer】17.打印从1到最大的n位数(JS实现)

题目描述

输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数 999。

示例 1:

输入: n = 1
输出: [1,2,3,4,5,6,7,8,9]

题目解答

循环解法

var printNumbers = function(n) {
    return Array.from({length:10**n -1 },(item, index) => index+1)
};

递归解法

var printNumbers = function (n) {
    if (n <= 0) {
        return 0;
    }
    var number = new Array();
    //var printArray = new Array();
    var res = [];
    for (var i = 0; i < n; i++) {
        number[i] = '0';
    }
    for (var i = 0; i < 10; i++) {
        number[0] = i + '';
        printOtherNumbers(number, n, 0);
    }
    function printOtherNumbers(number, length, index) {
        if (index == length - 1) {
            res.push(removeZero(number,length).join(''));
            return;
        }
        for (var i = 0; i < 10; i++) {
            number[index + 1] = i + '';
            printOtherNumbers(number, length, index + 1);
        }
    }
    res.shift();
    return res;
};
// 将数字前的零去掉
var removeZero = function (number,n) {
    var flag = false;
    var printArray = new Array();
    var j=0;
    for (var i = 0; i < n; i++) {
        if (number[i] != '0' && !flag) {
            flag = true;
           // printArray[j++] = number[i];
        }
        if (flag) {
            printArray[j++] = number[i];
        }
    }
    return printArray;
}
console.log(printNumbers(2));

知识点总结

1.Array.from方法

可以通过以下方式来创建对象:

  • 伪数组对象:拥有一个length属性和若干索引属性的任意对象
  • 可迭代对象:可以获取对象中的元素,如Map和Set等
Array.from([1,2,3],x => x+x);
//[2,4,6]

在Array.from中使用箭头函数

Array.from({length:5},(v,i) => i);
//[0,1,2,3,4]

序列生成器

const range = (start,stop,step) => Array.from({length: (stop-start)/step+1},(_,i)=> start +(i*step));
range(0,4,1);
//[0,1,2,3,4]

从类数组对象(arguments)生成数组

function f() {
  return Array.from(arguments);
}
f(1, 2, 3);
// [ 1, 2, 3 ]

2.map()方法

var numbers = [4, 9, 16, 25];

function myFunction() {
    x = document.getElementById("demo")
    x.innerHTML = numbers.map(Math.sqrt);
    // [2,3,4,5]
}

map()方法返回一个新数组,数组中的元素位原始数组元素调用函数处理后的值;

map()方法会按照原始数组元素顺序依次处理元素;

map()方法不会对空数组进行检测;

map()方法不会改变原始数组。

3.Map对象

Map对象保存键值对,是键/值对的集合。任何值都可作为一个键或一个值,Object对象提供了“字符串-值”的对应,Map对象提供了“值-值”的对应。

const map = new Map([[1, 2], [2, 4], [4, 8]]);
map.size;
//map中键值对的个数(3)

常用方法:

Map.clear();//清除所有
Map.delete(key); //清除某个键对应的值,并返回
Map.get(key); //获得
Map.has(key); //是否有
Map.keys(); //返回所有键
Map.set(key,value); //设置对应键的值,并返回该Map对象
Map.values();// 返回所有值
Map.entries(); //按插入顺序包含Map对象中每个元素的[key,value]数组

遍历:

for(let item of map.entries()){
    console.log(item[0],item[1]);
}

4.数组初始化

let number = new Array(n).fill(0)

该方法可以直接创建一个有n个元素的数组,且以数字0初始化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值