码迷,mamicode.com
首页 > 其他好文 > 详细

卡牌分组

时间:2020-01-26 13:14:18      阅读:59      评论:0      收藏:0      [点我收藏+]

标签:ever   mamicode   ret   class   push   pre   lse   com   default   

技术图片

技术图片

满足最小分组的长度为其他分组的整数倍

export default (arr) => {
  // 对这副牌进行排序,升序、降序都可以
  arr.sort((a, b) => a - b)
  let min = Number.MAX_SAFE_INTEGER
  let dst = []
  let result = true
  for (let i = 0, len = arr.length, tmp = []; i < len; i++) {
    tmp.push(arr[i])
    for (let j = i + 1; j < len - 1; j++) {
      if (arr[i] === arr[j]) {
        tmp.push(arr[j])
      } else {
        if (min > tmp.length) {
          min = tmp.length
        }
        // 因为数组为引用类型,直接push会导致出错
        dst.push([].concat(tmp))
        tmp.length = 0
        i = j
        break
      }
    }
  }
  dst.every(item => {
    if (item.length % min !== 0) {
      result = false
      return false
    }
  })
  return result
}

卡牌分组

标签:ever   mamicode   ret   class   push   pre   lse   com   default   

原文地址:https://www.cnblogs.com/ygjzs/p/12234070.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!