每日一题——LeetCode1103.分糖果 ||

方法一 个人方法:

有多少人就创建多大的数组并把数组的所有元素初始化为0,只要还有糖果,就循环给数组从头到尾添加糖果,每次分的糖果数递增1,最后可能刚好分完也可能不够,不够就还剩多少给多少。

var distributeCandies = function(candies, num_people) {
    var res = new Array(num_people).fill(0)
    var i=0
    while(candies>0){
        if(candies-i-1>=0){
            res[i%num_people]+=i+1
            candies-=i+1
        }else{
            res[i%num_people]+=candies
            candies=0
        }
        i++
    }
   return res
};

消耗时间和内存情况: 

方法二 数学公式

详细公式推导过程:

作者:力扣官方题解
链接:leetcode 1103 题解
 

var distributeCandies = function(candies, num_people) {
      let n = num_people 
    let p = Math.floor((2 * candies + 0.25)**0.5 - 0.5)
    let r = Math.floor(candies - (p + 1) * p * 0.5)
    let res = new Array(n).fill(0)
    let rows = Math.floor(p/n)
    let cols = p%n 
    for (let i = 0; i < n; i++) {
        res[i] = (i+1)*rows + Math.floor(rows * (rows - 1) * 0.5) * n 
        if(i<cols) res[i] += i+1+rows*n 
    }
    res[cols] += r 
    return res

};

消耗时间和内存情况:

 

相关推荐

  1. 1103. 糖果 II

    2024-01-12 20:02:01       7 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-12 20:02:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-12 20:02:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-12 20:02:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-12 20:02:01       18 阅读

热门阅读

  1. HAproxy群集

    2024-01-12 20:02:01       27 阅读
  2. Vue生命周期解析

    2024-01-12 20:02:01       34 阅读
  3. triton教程1:前言、安装、跑官方例子与推荐视频

    2024-01-12 20:02:01       37 阅读
  4. 类加载机制详解

    2024-01-12 20:02:01       32 阅读
  5. 设计模式原理与分析

    2024-01-12 20:02:01       35 阅读
  6. Npm+BootStrap布局

    2024-01-12 20:02:01       35 阅读