题目

Compare two version numbers version1 and version2.

If version1 > version2 return 1, if version1 < version2 return -1, otherwise return 0.

You may assume that the version strings are non-empty and contain only digits and the . character.

The . character does not represent a decimal point and is used to separate number sequences.

For instance, 2.5 is not “two and a half” or “half way to version three”, it is the fifth second-level revision of the second first-level revision.

Here is an example of version numbers ordering:

0.1 < 1.1 < 1.2 < 13.37

分析

方法一:

采用字符串比较;此题中的版本比较,需要将.号前的部分与第二部分分开比较;

方法二:

将版本号的字符串转化为整数;

AC代码

class Solution {
public:
/*方法一:字符串比较;如果version1 > version2 则返回1 相等返回0 反之返回-1*/
int compareVersion1(string version1, string version2) {
if (version1.empty() && version2.empty())
return 0;
else if (version2.empty())
return 1;
else if (version1.empty())
return -1;
else
{
//分别得到版本号的第一部分和第二部分
int pos = 0;
for (int i = 0; version1[i] != '\0' && version1[i] != '.'; ++i)
{
++pos;
}//for
string fir_version1;
string sec_version1;
if (pos == version1.length())
{
fir_version1 = version1;
sec_version1 = "";
}
else{
fir_version1 = version1.substr(0, pos);
sec_version1 = version1.substr(pos + 1, version1.length() - pos - 1);
}
//要略过第一部分版本号的开头的0
pos = 0;
while (fir_version1[pos] != '\0' && fir_version1[pos] == '0')
{
++pos;
}//while
if (fir_version1[pos] == '\0')
fir_version1 = "0";
else
fir_version1 = fir_version1.substr(pos, fir_version1.length() - pos); pos = 0;
for (int i = 0; version2[i] != '\0' && version2[i] != '.'; ++i)
{
++pos;
}//for
string fir_version2;
string sec_version2;
if (pos == version2.length())
{
fir_version2 = version2;
sec_version2 = "";
}
else{
fir_version2 = version2.substr(0, pos);
sec_version2 = version2.substr(pos + 1, version2.length() - pos - 1);
}//else pos = 0;
while (fir_version2[pos] != '\0' && fir_version2[pos] == '0')
{
++pos;
}//while
if (fir_version2[pos] == '\0')
fir_version2 = "0";
else
fir_version2 = fir_version2.substr(pos, fir_version2.length() - pos); if (strcmp(fir_version1.c_str(), fir_version2.c_str()) != 0)
return strcmp(fir_version1.c_str(), fir_version2.c_str());
else
return strcmp(sec_version1.c_str(), sec_version2.c_str());
}
} //方法二:化为整数比较
int compareVersion(string version1, string version2) {
int val1, val2;
int idx1 = 0, idx2 = 0;
while (idx1 < version1.length() || idx2 < version2.length()) {
val1 = 0;
while (idx1 < version1.length()) {
if (version1[idx1] == '.') {
++idx1;
break;
}
val1 = val1 * 10 + (version1[idx1] - '0');
++idx1;
}
val2 = 0;
while (idx2 < version2.length()) {
if (version2[idx2] == '.') {
++idx2;
break;
}
val2 = val2 * 10 + (version2[idx2] - '0');
++idx2;
}
if (val1 > val2) return 1;
if (val1 < val2) return -1;
}
return 0;
}
};

GitHub测试程序源码

最新文章

  1. 开源免费的天气预报接口API以及全国所有地区代码(国家气象局提供)
  2. Spring对Quartz的封装实现简单需注意事项
  3. iOS开发小技巧--UIButton的另一种布局方法(第一种在layoutSubViews方法中,这一种利用苹果提供的两个返回CGRect的方法)
  4. 兼容性好的CSS字体投影
  5. Bias and Variance
  6. SQL Server 2008 R2不支持limit(限制行数)
  7. activiti基础操作
  8. MAC终端配色Solarized
  9. asp.net core 认证及简单集群
  10. javascript实现限制上传文件的大小
  11. BZOJ 1652: [Usaco2006 Feb]Treats for the Cows( dp )
  12. Ion-affix &amp; Ion-stick 仿IOS悬浮列表插件
  13. JDBC知识详解
  14. Python类和对象
  15. eclipse上配置svn
  16. chrome extensions notifications
  17. db2 表空间扩容
  18. 使用tpcc-mysql进行性能测试
  19. 几种修改Linux主机名的方法
  20. asp.net如何判断服务器上的目录或文件是否存在

热门文章

  1. .Net Core 做请求监控NLog
  2. Linux (Windows Linux子系统)
  3. Redis特性之持久化机制
  4. 【转】 Oracle 中的一些重要V$ 动态性能视图,系统视图和表
  5. Appium基础四:Desired Capabilities详讲
  6. 快速搭建高可用 LNMP Web应用基础架构
  7. SQLServer 2012 报表服务部署配置(1)
  8. C# 简单创建和删除文件夹
  9. [VC]char 和 wchar_t相互转化
  10. [CV笔记]OpenCV机器学习笔记