资讯专栏INFORMATION COLUMN

入坑codewars

sherlock221 / 1767人阅读

摘要:,黑色的主题风格,很符合。时间复杂度虽然成功,但我明显感觉代码写得不是很优雅。这个是没错的,但缺乏了宏观的视角,会变得片面。但是不重要,关键是这个思想要学习,可以应用到其他地方。求和,大于就返回偶数的位置,否则返回奇数的位置。

前几天做LeetCode上的大数乘法,代码没错,可就是提交不成功,显示SyntaxError: Unexpected token var
我把所有代码都注释掉,只留下return 1,依然报同样的错误。。。感觉LeetCode对JSer不是特别友好
刚刚在node社区看到有人推荐codewars,立马去体验一番。注册要写个代码测试一下身份,这个细节有意思(虽然代码很简单)。
codewars,黑色的主题风格,很符合coder。而且可用语言非常广,连TypeScript都有!!
然后codewars给我推荐了一题=>codewars-iqTest

这题虽然很简单,但是很有意思,对我的启发挺大的,让我发现了自己的一些不足。
题目:意思就是要找出数串(不是数组,这是一个坑)中跟其他数不相同的一个数(奇偶方面)

我一开始的写法是:以第一个数的奇偶性为标准,后面的数跟这个标准一样,那就返回之前记录的一个跟这个标准不同的数的下标(如果有的话)。如果跟这个标准不同,那就记录下标。这样遍历完之后就如果还没有return,那结果就只能是第一个数或者最后一个数。判断一下seen就知道是头还是尾了。时间复杂度O(n)

function iqTest(numbers){
  let number = numbers.split(" ")
  let tag = number[0]%2
  let resIndex = ""
  let seen = false
  for(let i = 1, len = number.length; i < len; i++) {
    if(number[i]%2 === tag) {
      if(resIndex !== "") return resIndex+1
      seen = true
    }else {
      resIndex = i
    }
  }
  return seen? resIndex + 1: 1
}

虽然成功AC,但我明显感觉代码写得不是很优雅。在评论区看到有人用两个数组分别装奇数偶数,我恍然大悟,瞬间感觉自己宛如zz...我怎么一开始没想到orz
这一题完全暴露了我的不足,让我深思。遇到编程题,也许我更多地是在微观上进行思考,关注执行流程的每个细节,代码怎么执行。这个是没错的,但缺乏了宏观的视角,会变得片面。正所谓不识庐山真面目,只缘身在此山中,这一题如果宏观上把奇偶剥离,那什么问题都解决了,简直不要太简单!!

function iqTest(numbers){
  let number = numbers.split(" ")
  let odd = [],even = []
  number.forEach((item,index) => {
    item % 2 == 0? even.push(index + 1): odd.push(index + 1)
  })
  return odd.length === 1? odd[0]: even[0]
}

短短几行代码,也是一次遍历,时间复杂度O(n),这才是优雅地写代码!(看到社区高票答案有用filter扫两次,我觉得用forEach一次就够了)
此外,AC之后还能看大佬们的代码,按clever排序,看到了一下代码:


看到这样的代码,我真的有点兴奋,想法太妙了!虽然包含indexOf,一共遍历了三遍。但是不重要,关键是这个思想要学习,可以应用到其他地方。
首先他用map将每个元素模2,这就像同化一样,因为只有奇数和偶数,所以先把奇数和偶数都分别同化成一个样,0或1。求和,大于1就返回偶数的位置,否则返回奇数的位置。
不过我觉得reduce累加的步骤没有必要,只要把前三个数加起来就知道不同的数的奇偶性,或者可以在第一次遍历就记录0或1的数量,省一次遍历。

喜欢codewars,这里人个个都是人才,说话又好听

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/108166.html

相关文章

  • CodeWars 上面的奇葩问题和回答(一)

    摘要:其实昨天晚上我看到最逗得一段代码是这样的,老外的创造力真是震古烁今啊,题目是写一个函数查找素数。 这两天有点迷Codewars , 这上面的好处是奖励系统,我为了升段位晚上像打游戏升级一样的在做js习题,想想老外哪怕这简单网站的任务系统做的可真够好啊。 先给大家介绍第一道 六段题(一共8kyu,kyu上面还有dan,数字越小越难) 题目: 创造一个函数,返回如下这么个玩意,参数...

    gggggggbong 评论0 收藏0
  • [到codewars打怪兽]串串香

    摘要:问题描述验证方式题目理解函数处理一个参数,一个字符串组。常量值,可以是任意合法的表达式。到字符串长度的一个整数。可选,用于指定连接每个数组元素的分隔符。分隔符会被转成字符串类型如果省略的话,默认为一个逗号。 [7 kyu]Substring fun ⌚️2016.02.22 问题描述: showImg(http://ww1.sinaimg.cn/large/006m2mhTgw1f1p...

    2json 评论0 收藏0
  • CodeWars 上面的奇葩问题(二)

    工作之余在codewars上看了一个问题,题目如下 写一个正则,验证密码,保证以下几点, 0.位数大于六 1.必须包含小写字母 2.必须包含大写字母 3.必须包含数字 好吧,我搞了半天没搞出来,各位看官,你们知道怎么解吗? 答案我参考了google,使用一条正则表达式是这样的 function validate(password) ...

    TANKING 评论0 收藏0
  • 刷题——Codewars Js题目(持续更新)

    摘要:发现一个很好的练习做题网站都是自己做过的,先放自己的答案,再放自己觉得不错的其他回答。 发现一个很好的练习做题网站 Codewars 都是自己做过的,先放自己的答案,再放自己觉得不错的其他回答。 1. 将首字母放到后面并加上ay pigIt(This is my string)转换成:pigIt(hisTay siay ymay tringsay) mine function...

    toddmark 评论0 收藏0
  • [到codewar打怪兽]你这小孩看到长辈怎么不打招呼

    摘要:你这小孩看到长辈怎么不打招呼怪兽的属性怪兽的技能无大木博士的图鉴把它函数弄好来,让他可以好好地欢迎客人战斗记录仪回放注解访问对象的属性。在通过来调用函数调用对象。失误并不是全局对象。国际战场的经典录像不需。 [8 kyu]Broken Greetings 你这小孩看到长辈怎么不打招呼⌚️2016.03.15 怪兽的属性: showImg(http://ww3.sinaimg.cn/la...

    rainyang 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<