[7kyu]Sum of Odd Cubed Numbers

该算法题来自于 codewars【语言: javascript】,翻译如有误差,敬请谅解~

  • 任务
    • 查找并返回数组中奇数的立方和。只要其中某一个值不是数字,此函数将返回undefined(在PHP中为NULL)。
  • 例如:
    cubeOdd([1, 2, 3, 4]),返回 28。
    cubeOdd([-3,-2,2,3]),返回 0。
    cubeOdd(["a",12,9,"z",42]),返回 undefined。

  • 解答
  • 其一
const cubeOdd = arr => {
      const array = arr.filter(el=>typeof el != 'number');
      let sum = 0;
      array.length ? sum = undefined : arr.filter(el=>el%2).forEach(el => {sum += Math.pow(el,3)});
      return sum;
}
  • 其二
function cubeOdd(arr) {
      var sum = 0;
      for (var i = 0; i <arr.length; i++){
        var cubed = (arr[i]*arr[i]*arr[i]);
        if (isNaN(cubed)) return undefined;
        if(cubed % 2 != 0 )sum += cubed;
      }
      return sum;
}
  • 其三
const cubeOdd = arr => arr.some(x=> +x !== x) ? undefined : arr.filter(x=>x%2!=0).reduce((s,x)=>s+x**3,0);
  • 其四
const undefiner = v => isNaN(v) ? undefined : v;
const cubeOdd = arr => undefiner(arr.reduce((s, v) => s + v*v%2*v*v*v, 0));
  • 其五
const cubeOdd=a=>a.filter(x=>typeof x != "number").length?undefined:a.filter(x=>x%2).map(x=>Math.pow(x,3)).reduce((a,b)=>a+b,0)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 该算法题来自于 codewars【语言: javascript】,翻译如有误差,敬请谅解~ 场景给你一个包含一些正...
    君肄塵阅读 1,930评论 0 0
  • 本文转载自@陈铮半年前的博文,原文地址:JavaScript Array 原型方法 大盘点 数组是一个超常用的数据...
    浙大javascript联盟阅读 4,400评论 0 4
  • 3月5日,我第一次作为管理员运营一个小社群——朱子先生摄影修图训练营第二期,收获颇丰感想颇多,决定在临近一周期的时...
    夏木生长阅读 4,017评论 6 8
  • 清明放假回去的第二天早上,我起的早,慢悠悠的溜达着来到田里。也不知怎么,在外时间久了,回来总是情不自禁的想到田里走...
    陪月亮摘星星阅读 3,365评论 11 14
  • 桜があんなに洁く散のは来年も咲くのわかってるからだよ。 “我觉得骄傲是一般人的通病”,梅莉说,她觉得她的见解非常了...
    邦枝阅读 3,325评论 0 0