zoukankan      html  css  js  c++  java
  • 生成[1,2,,3,4,5,6,7,8,9]的随机数组?

          今天突然看到了一道有关js的题,想了一下,没有想出怎么做,我是一个小白,在学习的道路上,此时心想认真琢磨一下吧,下面是自己琢磨的过程。

          第一步:当然是声明一个存放随机数的数组啦,其次数组里面有1-9,需要9个值,很明显需要循环,在想在什么条件下循环呢,因为数组是从0计数的,所以循环条件

    i的值取0-8,即i<9或i<=8.

    我在最后打印了一下结果,运行结果:[3,9,4,4,8,3,0,2,9]是生成了9个数,但是很明显有三个错误:(1)  结果中含有“0”   (2)有重复的数字  (3)数字没有排序

    只要把这三个问题解决了就0k了。

           

       第二步:首先解决第一个问题

    随机数放进数组前首先判断下是不是大于0,然而运行结果却是怎样:[7,9,7,9,3,3,1,6],什么?为什么只有8个数,原来是有一个值为0,被残忍的关在数组外了,但是它还穿着带有编号的衣服,那该怎么办呢,导致会少好多值,让我们遇到这种情况来个else,运行一下结果为[9,7,2,7,3,1,5,4,6],第一个问题算是解决了。

          

         第三步:就是数组去重,就是把生成的随机数与数组之前已有的所有数字进行比较,结果都不一样,然后再放进去,如果有一个一样的,是不是也要把它带有编号的衣服脱掉啊,现在新的随机数只要不和已有的任何一个不同就可以放进去了,我们加个计数器,计数器最终的值和已有数组的length相等就可以把新的随机数放进数组了,计数器肯定要加在生成随机数循环的里面,因为每次生成新的随机数计计时器都要清空。

         

         第四步,数组排序,大家都知道数组的sort()方法,但是数字排序会出现问题,比如:1,2,11,22,进行排序会出现问题,输出:1,11,2,22,它只会根据第一位数字进行排序,所以我们要加一个排序函数,function sortnum(a,b){return a-b;},从小到大是a-b,从大到小是b-a,字母只用sort()

     总结:个人是小白,只能慢慢来,从简单的做起,一点一点的掌握。如有大神偶然路过,勿喷。

      
  • 相关阅读:
    7.20 高博教育 方法
    7.20 高博教育 随机数字(练习)
    7.17 高博教育 流程控制02
    7月17号 高博教育 复习加逻辑运算符
    7月16号 高博教育 知识扩展
    7月16号 高博教育 知识点总结
    7月16号 高博教育 数据运算符和比较运算符
    链式线性表——课上练
    顺序线性表——课上练
    链栈——课上练
  • 原文地址:https://www.cnblogs.com/tangshuixian8/p/5859910.html
Copyright © 2011-2022 走看看