2020/3/3 晚上笔试题(前端)

晚上的笔试题只有 Node 版本的 JavaScript。。。。好在是写函数,而不是要读取用户输入~

实现一个函数 versionCompare(a, b) ,比较两个版本号字符串的大小。
如果a版本大于b,返回-1
a版本等于b,返回0
a版本小于b,返回1
用例:
输入: a = ‘3.0.14’, b = ‘2.0.11’
输出: -1

输入: a = ‘3’ , b = ‘3.0.0’
输出: 0

    function versionCompare(a, b) {
      // write code here
      let arra = a.split('.');
      let arrb = b.split('.');
      const alen = arra.length,
        blen = arrb.length;
      for (let i = 0; i < alen; i++) {
        if (arra[i] !== '') {
          arra[i] = parseInt(arra[i])
        } else {
          arra[i] = 0;
        }
      }
      for (let i = 0; i < blen; i++) {
        if (arrb[i] !== '') {
          arrb[i] = parseInt(arrb[i])
        } else {
          arrb[i] = 0;
        }
      }
      if (alen < blen) {
        arra = arra.concat(Array(blen - alen).fill(0));
      }
      if (blen < alen) {
        arrb = arrb.concat(Array(alen - blen).fill(0));
      }
      len = Math.max(alen,)
      for (let i = 0; i < len; i++) {
        if (parseInt(arra[i]) < parseInt(arrb[i])) {
          return 1;
        }
        if (parseInt(arra[i]) > parseInt(arrb[i])) {
          return -1;
        }
      }
      return 0;

实现一个函数 searchNumber(str),找出给定字符串中的所有数字,组成一个数组并返回它。
示例:
输入: ‘我今年22岁,2020年6月要去啦!’
输出:[22, 2020, 6]

function searchNumber(str) {
    const reg = /\d+/g;
    const arr = [];
    str.match(reg).forEach((value) => {
      arr.push(parseInt(value));
    });
    return arr;
}
全部评论

相关推荐

头像
10-14 23:01
已编辑
中国地质大学(武汉) Java
CUG芝士圈:虽然是网上的项目,但最好还是包装一下,然后现在大部分公司都在忙校招,十月底、十一月初会好找一些。最后,boss才沟通100家,别焦虑,我去年暑假找第一段实习的时候沟通了500➕才有面试,校友加油
点赞 评论 收藏
分享
头像
10-16 09:58
已编辑
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务