一串数字的和 = 平均值 * 数字个数

和为S的连续正数序列

http://www.nowcoder.com/questionTerminal/c451a3fd84b64cb19485dad758a55ebe

一串数字的和 = 平均值 * 数字个数;
连续数字的平均值分为两种情况:

  1. 奇数个数字:中位数、(整数)
  2. 偶数个数字:中间两个数的平均 (xx.5)

所以我们要找的就是:符合条件的平均值和数字个数:

  1. 平均值为整数,数字个数必定为奇数
  2. 平均值为xx.5, 数字个数必定为偶数

假设刚开始有i(0~sum)个数字,所以平均值为: sum/i,找到符合条件的,然后根据平均值和数字个数生成一串数字就好了

JavaScript:

function FindContinuousSequence(sum)
{
  const res = []
  for(let i=2; i<sum; i++){
    const mid = sum/i; // mid为结果中间的数字,i是一共有几个数字
    if(mid - i/2 <= 0) break;  // 开头的数字小于0,就不对了
    // mid为整数的时候i必须是奇数,mid为.5的时候,i必须是偶数
    if((mid%1 === 0 && i%2 === 1) || (mid%1 === 0.5 && i%2 === 0)){
      res.unshift(createNums(mid, i))
    }
  }
  return res
}

function createNums(mid, count){
  let arr = [];
  let i=0;
  if(count%2 === 1){
    i=1;
    arr.push(mid)
  }else{
    i=0.5
  }
  for(; i< Math.ceil(count/2); i++){
    arr.push(mid+i)
    arr.unshift(mid-i)
  }
  return arr
}
全部评论
我也是这个思路做的,python,从ide上测试可以,到OJ上输入s=4的时候,返回值为[[0, 1]],好奇怪啊
点赞 回复 分享
发布于 2020-04-21 22:01

相关推荐

菜菜咪:1. 可以使用简历网站的模版,美观度会更好一点 2. 邮箱可以重新申请一个,或者用qq邮箱的别名,部分hr可能会不喜欢数字邮箱 3. 项目经历最好分点描述,类似的项目很多,可以参考一下别人怎么写的 4. 自我评价可加可不加,技术岗更看重技术。最后,加油,优秀士兵
点赞 评论 收藏
分享
评论
5
收藏
分享
牛客网
牛客企业服务