广西柳州网站制作公司,h5个网站的区别,邯郸市住房和建设官方网站,北京网络推广公司排行给你两个版本号 version1 和 version2 #xff0c;请你比较它们。
版本号由一个或多个修订号组成#xff0c;各修订号由一个 ‘.’ 连接。每个修订号由 多位数字 组成#xff0c;可能包含 前导零 。每个版本号至少包含一个字符。修订号从左到右编号#xff0c;下标从 0 开…给你两个版本号 version1 和 version2 请你比较它们。
版本号由一个或多个修订号组成各修订号由一个 ‘.’ 连接。每个修订号由 多位数字 组成可能包含 前导零 。每个版本号至少包含一个字符。修订号从左到右编号下标从 0 开始最左边的修订号下标为 0 下一个修订号下标为 1 以此类推。例如2.5.33 和 0.1 都是有效的版本号。
比较版本号时请按从左到右的顺序依次比较它们的修订号。比较修订号时只需比较 忽略任何前导零后的整数值 。也就是说修订号 1 和修订号 001 相等 。如果版本号没有指定某个下标处的修订号则该修订号视为 0 。例如版本 1.0 小于版本 1.1 因为它们下标为 0 的修订号相同而下标为 1 的修订号分别为 0 和 1 0 1 。
返回规则如下
如果 version1 version2 返回 1 如果 version1 version2 返回 -1 除此之外返回 0。
示例 1
输入version1 “1.01”, version2 “1.001” 输出0 解释忽略前导零“01” 和 “001” 都表示相同的整数 “1” 示例 2
输入version1 “1.0”, version2 “1.0.0” 输出0 解释version1 没有指定下标为 2 的修订号即视为 “0” 示例 3
输入version1 “0.1”, version2 “1.1” 输出-1 解释version1 中下标为 0 的修订号是 “0”version2 中下标为 0 的修订号是 “1” 。0 1所以 version1 version2
提示
1 version1.length, version2.length 500 version1 和 version2 仅包含数字和 ‘.’ version1 和 version2 都是 有效版本号 version1 和 version2 的所有修订号都可以存储在 32 位整数 中
class Solution {
public:int compareVersion(string version1, string version2) {for(int i 0, j 0; i version1.size() || j version2.size(); ) {int a i, b j;while(a version1.size() version1[a] ! .) a ;while(b version2.size() version2[b] ! .) b ;int x a i ? 0 : stoi(version1.substr(i, a - i));int y b j ? 0 : stoi(version2.substr(j, b - j));if(x y) return 1;if(x y) return -1;i a 1, j b 1;}return 0;}
};