Leetcode每日一练--35

165. 比较版本号

难度:中等

提示

给你两个 版本号字符串 version1version2 ,请你比较它们。版本号由被点 '.' 分开的修订号组成。修订号的值 是它 转换为整数 并忽略前导零。

比较版本号时,请按 从左到右的顺序 依次比较它们的修订号。如果其中一个版本字符串的修订号较少,则将缺失的修订号视为 0

返回规则如下:

  • 如果 version1 < version2 返回 -1
  • 如果 version1 > version2 返回 1
  • 除此之外返回 0

示例 1:

**输入:**version1 = "1.2", version2 = "1.10"

输出:-1

解释:

version1 的第二个修订号为 "2",version2 的第二个修订号为 "10":2 < 10,所以 version1 < version2。

示例 2:

**输入:**version1 = "1.01", version2 = "1.001"

**输出:**0

解释:

忽略前导零,"01" 和 "001" 都代表相同的整数 "1"。

示例 3:

**输入:**version1 = "1.0", version2 = "1.0.0.0"

**输出:**0

解释:

version1 有更少的修订号,每个缺失的修订号按 "0" 处理。

提示:

  • 1 <= version1.length, version2.length <= 500
  • version1version2 仅包含数字和 '.'
  • version1version2 都是 有效版本号
  • version1version2 的所有修订号都可以存储在 32 位整数

代码

cpp 复制代码
int compareVersion(char* version1, char* version2) {
    while (*version1 || *version2) {
        int num1 = 0, num2 = 0;
        
        // 提取version1当前段的整数
        while (*version1 && *version1 != '.') {
            num1 = num1 * 10 + (*version1 - '0');
            version1++;
        }
        if (*version1 == '.') version1++; // 跳过点
        
        // 提取version2当前段的整数
        while (*version2 && *version2 != '.') {
            num2 = num2 * 10 + (*version2 - '0');
            version2++;
        }
        if (*version2 == '.') version2++; // 跳过点
        
        // 比较当前段
        if (num1 < num2) return -1;
        if (num1 > num2) return 1;
    }
    return 0; // 所有段均相等
}
相关推荐
佚名ano几秒前
支持向量机SVM的简单推导过程
算法·机器学习·支持向量机
云泽8082 分钟前
蓝桥杯算法精讲:倍增思想与离散化深度剖析
算法·职场和发展·蓝桥杯
m0_569881473 分钟前
基于C++的数据库连接池
开发语言·c++·算法
.select.10 分钟前
c++ auto
开发语言·c++·算法
2401_8845632413 分钟前
C++中的访问者模式高级应用
开发语言·c++·算法
智者知已应修善业18 分钟前
【51单片机用两个定时计数器级联实现定时】2023-04-12
c语言·经验分享·笔记·算法·51单片机
君义_noip19 分钟前
信息学奥赛一本通 1613:打印文章
c++·算法·信息学奥赛·csp-s
nglff27 分钟前
蓝桥杯抱佛脚第四天|前缀和,差分对应练习
算法·职场和发展·蓝桥杯
freexyn43 分钟前
Matlab入门自学七十四:坐标系转换,直角坐标、极坐标和球坐标的转换
开发语言·算法·matlab
咱就是说不配啊1 小时前
3.20打卡day34
数据结构·c++·算法