LeetCode-165. 比较版本号

210 篇文章 0 订阅
206 篇文章 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
示例 4:

输入:version1 = "1.0.1", version2 = "1"
输出:1
示例 5:

输入:version1 = "7.5.2.4", version2 = "7.5.3"
输出:-1
 

提示:

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

实在是太巧了。最近,正好做的项目也遇到比较版本类似的需求。

重新写了一下,这次经过测试用例。我觉得这个比较函数可以使用了。

#include<iostream>
#include<string>
#include<vector>
using namespace std;

class Solution {
public:
	int compareVersion(string version1, string version2) {

		int ret = 0;                     //默认相等
		vector<int> verVec1, verVec2;
		size_t len1, len2, maxlen;
		createVersionVec(verVec1, version1);
		createVersionVec(verVec2, version2);

		len1 = verVec1.size();
		len2 = verVec2.size();

		/* 没有一个 "."的情况,默认就用原始version做比较 */
		if (len1 == 0) {
			verVec1.push_back(stoi(version1));
			len1++;
		}
		if (len2 == 0) {
			verVec2.push_back(stoi(version2));
			len2++;
		}

		/* 出现某一个数组的长度不够的情况,用0补齐 */
		maxlen = max(len1, len2);
		while (len1 < maxlen) {
			verVec1.push_back(0);
			len1++;
		}
		while (len2 < maxlen) {
			verVec2.push_back(0);
			len2++;
		}


		for (size_t i = 0; i < maxlen; i++) {
			if (verVec1[i] > verVec2[i]) {
				ret = 1;
				goto L_Over;
			}
			else if (verVec1[i] < verVec2[i]) {
				ret = -1;
				goto L_Over;
			}
		}

	L_Over:
		return ret;
	}

private:
	size_t max(size_t a, size_t b) {
		return (a >= b ? a : b);
	}

	/* 以"."切割字符串,并生成vector<int>数组用于对比 */
	void createVersionVec(vector<int>& vec, string version) {
		string::size_type lIndex = 0, rIndex = 0;   //lIndex作为左边界,rIndex作为'.'的下标
		string tmpVer;
		for (char c : version) {
			if (c == '.') {
				tmpVer = version.substr(lIndex, rIndex - lIndex);
				lIndex = rIndex + 1;
				vec.push_back(stoi(tmpVer));
			}
			rIndex++;
		}

		if (lIndex > 0) {
			tmpVer = version.substr(lIndex, rIndex - lIndex);
			vec.push_back(stoi(tmpVer));
		}
	}
};

int main() {
	Solution* ps = new Solution();
	string version = "7.5.2.4.23.122.44.56";
	cout << ps->compareVersion("1", "0") << endl;

	system("pause");
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Leetcode题库是一个包含了各种算法和数据结构问题的在线题库,供程序员练习和提升技能使用。这个题库中涵盖了大量的题目,包括但不限于图遍历、最短路径、有效的括、字符串解码、Z字形变换、最长公共前缀、字符串相乘、颠倒字符串中的单词、比较版本号、反转字符串、压缩字符串、验证IP地址等等。它提供了java实现的leetcode解法,这些解法的代码规范,可读性良好,并且其中的解法思想并不受语言限制。通过解决这些题目,程序员可以提高自己的算法和编码能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [leetcode题库-leetcode-java:LeetcodeJava代码](https://download.csdn.net/download/weixin_38661100/19901136)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [LeetCode算法题整理(200题左右)](https://blog.csdn.net/qq_38253797/article/details/126827454)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值