【算法题】比较两个版本号的大小(js)



js 复制代码
const lines = ["5.2", "5.1a"];
const lines1 = ["5.6.1", "5.6.2a"];
const lines2 = ["5.6.8.a", "5.6.8.0a"];
const lines3 = ["5.06.08.a", "5.6.8.0a"];
const lines4 = ["5", "5.0.0.0"];
function solution(lines) {
  const [verson1, version2] = lines;
  if (!isValid(verson1) || !isValid(version2)) return 0;
  const str1 = verson1.replace(/[\.0]/g, "");
  const str2 = version2.replace(/[\.0]/g, "");
  return parseInt(str1) !== parseInt(str2)
    ? parseInt(str1) > parseInt(str2)
      ? 1
      : -1
    : 0;
  console.log(str1, str2);
  function isValid(ver) {
    if (/[^0-9a-zA-Z.]/.test(ver)) return false;
    const arr = ver.split(".");
    if (arr.length < 1) return false;
    return true;
  }
}

console.log(solution(lines));
/* 
5.2
5.1a
=> 1

5.6.1
5.6.2a
=>
-1

5.6.8.a
5.6.8.0a
=>
0

const lines3 = ["5.06.08.a", "5.6.8.0a"];  预计 0
const lines4 = ["5", "5.0.0.0"];    预计 0
 */
相关推荐
Ama_tor24 分钟前
obsidian进阶の插件系列|Templater从小白到菜鸟
javascript·markdown·插件·obsidian
程序员-King.24 分钟前
day151—双端队列—找树左下角的值(LeetCode-513)
算法·leetcode·二叉树·双端队列·队列
WordPress学习笔记30 分钟前
解决Bootstrap下拉菜单一级链接无法点击的问题
前端·bootstrap·html
苦藤新鸡31 分钟前
15 .数组右移动k个单位
算法·leetcode·动态规划·力扣
Never_Satisfied38 分钟前
C#插值字符串中大括号表示方法
前端·c#
wuhen_n41 分钟前
初识TypeScript
javascript·typescript
狐5742 分钟前
2026-01-19-牛客每日一题-阅读理解
笔记·算法·牛客
w***76551 小时前
JS vs jQuery:核心差异解析
开发语言·javascript·jquery
踢球的打工仔1 小时前
typescript-类
前端·javascript·typescript
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——力扣 130 题:被围绕的区域
算法·leetcode·职场和发展·结构与算法