js判断两个版本号的大小

function compareVersion(v1, v2) {
  if (v1 == v2) {
    return 0;
  }

  const vs1 = v1.split(".").map(a => parseInt(a));
  const vs2 = v2.split(".").map(a => parseInt(a));

  const length = Math.min(vs1.length, vs2.length);
  for (let i = 0; i < length; i++) {
    if (vs1[i] > vs2[i]) {
      return 1;
    } else if (vs1[i] < vs2[i]) {
      return -1;
    }
  }

  if (length == vs1.length) {
    return -1;
  } else {
    return 1;
  }
}
//情况一:
compareVersion('2.2.3','2.2.2');   //1
//当 v1 大于 v2 时返回  1

//情况二:
compareVersion('2.2.2','2.2.2');   //0
//当 v1 等于 v2 时返回  0

//情况二:
compareVersion('1.2.3','2.2.2');   //-1
//当 v1 小于 v2 时返回  -1

注意事项:

es5环境运行请使用

function compareVersion(v1, v2) {
  if (v1 == v2) {
    return 0;
  }

  var vs1 = v1.split(".").map(a => parseInt(a));
  var vs2 = v2.split(".").map(a => parseInt(a));

  var length = Math.min(vs1.length, vs2.length);
  for (var i = 0; i < length; i++) {
    if (vs1[i] > vs2[i]) {
      return 1;
    } else if (vs1[i] < vs2[i]) {
      return -1;
    }
  }

  if (length == vs1.length) {
    return -1;
  } else {
    return 1;
  }
}
Python可以通过比较版本号大小判断它们的顺序。有多种方法可以实现这个功能。引用\[1\]中的代码使用了一个类来比较两个版本号大小。它首先将版本号转换为列表,并使用0补齐使两个列表的长度相等。然后对列表进行排序,并根据排序后的结果判断版本号大小。如果两个版本号相等,则输出相等的信息;如果第一个版本号小于第二个版本号,则输出小于的信息;否则输出大于的信息。 引用\[2\]中的代码也是用来比较两个版本号大小。它首先定义了一个函数来去除版本号中的前导0,并将大版本按"."切割为子版本列表。然后通过比较两个版本号列表的元素来判断它们的大小。如果两个版本号相等,则返回0;如果第一个版本号小于第二个版本号,则返回-1;否则返回1。 引用\[3\]中的代码也是用来比较两个版本号大小。它将版本号转换为列表,并通过循环比较列表中的元素来判断它们的大小。如果两个版本号相等,则继续比较下一个元素;如果第一个版本号小于第二个版本号,则返回-1;否则返回1。最后,根据列表的长度来判断哪个版本号更高。 综上所述,以上三种方法都可以用来比较两个版本号大小。你可以根据自己的需求选择其中一种方法来使用。 #### 引用[.reference_title] - *1* [python判断2个版本号大小](https://blog.youkuaiyun.com/lizy0327/article/details/121164549)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [华为OD机试 - 比较两个版本号大小(Java & JS & Python)](https://blog.youkuaiyun.com/qfc_128220/article/details/128179974)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [python 比较两个版本号大小](https://blog.youkuaiyun.com/tinyjm/article/details/93514261)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值