基于js实现抽红包并分配代码实例


Posted in Javascript onSeptember 19, 2019

这篇文章主要介绍了基于js实现抽红包并分配代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

将 50000元随机分给10个人,其中3个人必须分到百位数,4个人分到千位数,3个人分到万位数,每个人所得金额

<!DOCTYPE html>
<html lang="zh">
<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  <title>Document</title>
</head>
<body>
  将 50000元随机分给10个人,其中3个人必须分到百位数,4个人分到千位数,3个人分到万位数,每个人所得金额
</body>
<script type="text/javascript">   
  /**
   *
   * @param {Object} amount 总数钱
   * @param {Object} list [2,2,2,3,3,3,3,4,4,4] 3个百位,4个千位,3个万位
   */   
  //不要小数
  function devide(amount,list){
    var len = list.length;     
    //先计算所有的自身位数范围
    var arr = [];
    for(var i = 0; i < len; i++){
      var item = getRange(list[i]);
       
      arr.push(item);
    }     
    var res = [];
    //只算n-1位,剩下最后一个,不用计算
    for(var i = 0; i < len-1; i++){
      var index = Math.floor(Math.random() * arr.length); //随机获取一个,然后用来取
      var item = arr.splice(index,1)[0]; //取出当前需要发的红包位数
      var result = calc(amount,item,arr);
      if(result){
        res.push(result);
        amount = amount - result;
      }else{
        return [];
      }
    }     
    if(arr[0].start > amount || arr[0].end < amount){
      console.warn("分配出现错误,请重新规划分配方案");
      return [];
    }     
    res.push(amount);
    return res;
  }   
  function calc(amount,item,arr){  
    //当其他的都取最小值时的总和,为了保证每个都分到
    var otherRange = getOtherRange(arr);
    var minStart = otherRange.countStart;
    var maxEnd = otherRange.countEnd;
    var mins = amount - minStart; //剩余可取
    var end = item.end;
    var start = item.start;
    if(start > mins){
      console.warn("分配出现错误,请重新规划分配方案");
      return false;
    }else if(end > mins){
      //如果最大范围大于剩余的
      end = mins;
    }     
    //则随机抽取从 start至end     
    var result = Math.floor(Math.random()*(end-start) + start);
     
    if(amount - result > maxEnd){
      //取的值太小,其他的取最大值也分不完
      console.warn("分配出现错误,请重新规划分配方案");
    }
     
    return result;
  }   
  //获取某位的范围
  function getRange(item){
    return {
      start:Math.pow(10,item),   //比如百位2,这里最小就是100
      end: Math.pow(10,item+1) - 1 //百位最大为 1000-1
    }
  }   
  //获取所有的范围
  function getOtherRange(arr){
    var countStart = 0;
    var countEnd = 0;
    for(var i = 0; i < arr.length; i++){
      countStart += arr[i].start;
      countEnd += arr[i].end;
    }
    return {
      countStart,
      countEnd
    };
  }
  console.log(devide(50000,[2,2,2,3,3,3,3,4,4,4]))
</script>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery tab标签页的制作
May 10 Javascript
Javascript 中 null、NaN和undefined的区别总结
Apr 10 Javascript
jQuery .attr()和.removeAttr()方法操作元素属性示例
Jul 16 Javascript
用js传递value默认值的示例代码
Sep 11 Javascript
JavaScript实现文字与图片拖拽效果的方法
Feb 16 Javascript
Backbone.js的一些使用技巧
Jul 01 Javascript
jquery获取select选中值的方法分析
Dec 22 Javascript
基于JavaScript实现单选框下拉菜单添加文件效果
Jun 26 Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 Javascript
深入浅出webpack之externals的使用
Dec 04 Javascript
JS实现标签滚动切换效果
Dec 25 Javascript
JavaScript 处理树数据结构的方法示例
Jun 16 Javascript
Layui table field初始化加载时进行隐藏的方法
Sep 19 #Javascript
Vue 实例事件简单示例
Sep 19 #Javascript
微信小程序常用的3种提示弹窗实现详解
Sep 19 #Javascript
微信小程序防止多次点击跳转和防止表单组件输入内容多次验证功能(函数防抖)
Sep 19 #Javascript
vue 设置 input 为不可以编辑的实现方法
Sep 19 #Javascript
node 标准输入流和输出流代码实例
Sep 19 #Javascript
解决layui数据表格排序图标被超出的表头挤出去的问题
Sep 19 #Javascript
You might like
PHP6 中可能会出现的新特性预览
2014/04/04 PHP
php实现的返回数据格式化类实例
2014/09/22 PHP
分享常见的几种页面静态化的方法
2015/01/08 PHP
php简单生成随机数的方法
2015/07/30 PHP
php中get_magic_quotes_gpc()函数说明
2017/02/06 PHP
Thinkphp5 微信公众号token验证不成功的原因及解决方法
2017/11/12 PHP
破解Session cookie的方法
2006/07/28 Javascript
讨论javascript(一)工厂方式 js面象对象的定义方法
2009/12/15 Javascript
通过jQuery源码学习javascript(三)
2012/12/27 Javascript
Javascript基础教程之数据类型 (字符串 String)
2015/01/18 Javascript
浅谈JavaScript中的String对象常用方法
2015/02/25 Javascript
使用jquery清空、复位整个输入域
2015/04/02 Javascript
JavaScript将字符串转换为整数的方法
2015/04/14 Javascript
JavaScript中使用concat()方法拼接字符串的教程
2015/06/06 Javascript
js生成随机数的过程解析
2015/11/24 Javascript
javascript中Date format(js日期格式化)方法小结
2015/12/17 Javascript
JS自定义函数实现时间戳转换成date的方法示例
2017/08/27 Javascript
jQuery实现简单的回到顶部totop功能示例
2017/10/16 jQuery
解决webpack dev-server不能匹配post请求的问题
2018/08/24 Javascript
解决vue 绑定对象内点击事件失效问题
2018/09/05 Javascript
在Vue 中使用Typescript的示例代码
2018/09/10 Javascript
JavaScript实现图片的放大缩小及拖拽功能示例
2019/05/14 Javascript
[37:47]IG vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python实现寻找最长回文子序列的方法
2018/06/02 Python
python之当你发现QTimer不能用时的解决方法
2019/06/21 Python
通过python调用adb命令对App进行性能测试方式
2020/04/23 Python
巴西美妆购物网站:Kutiz Beauté
2019/03/13 全球购物
ghd法国官方网站:英国最受欢迎的美发工具品牌
2019/04/18 全球购物
美国环保妈妈、儿童和婴儿用品购物网站:The Tot
2019/11/24 全球购物
办公设备采购方案
2014/03/16 职场文书
教师节活动主持词
2014/04/02 职场文书
关于环保的演讲稿
2014/05/10 职场文书
工作会议方案
2014/05/21 职场文书
开展党的群众路线教育实践活动个人对照检查材料
2014/11/05 职场文书
2015年仓库管理员工作总结
2015/04/21 职场文书
2015年信贷员工作总结
2015/04/28 职场文书