题目:

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

题目属于简单级别,还是挺复杂的,思路:将字符串按照"."分割,将“.”之间的数字转化为整数,然后分别对应比较。例如:1.2和13.37,分别转化为数组[1,2]和[13,37],从前往后对应比较1比13小,这时就可以得出结论1.2<13.37,若相等,则继续向后比较。这里需要注意,若两个字符串转化的数组不等长,需要将短的数组后面补0,例如,1.1和1.1.0,前者转化为[1,1],后者是[1,1,0],这时需要将前者补齐为[1,1,0],然后再对应比较。代码如下:

public int compareVersion(String version1, String version2) {
//.的个数
int dot_num1 = 0;
int dot_num2 = 0;
for(int i = 0;i<version1.length();i++)
{
if(version1.charAt(i)=='.')
dot_num1 ++;
}
for(int i = 0;i<version2.length();i++)
{
if(version2.charAt(i)=='.')
dot_num2 ++;
}
//按照.的位置截取子串
String arr1[] = new String[dot_num1+1];
String arr2[] = new String[dot_num2+1];
//记录每个字符串中的.的个数
int index1[] = new int[dot_num1+2];
int index2[] = new int[dot_num2+2]; int in1 = 1;
index1[0] = -1;
for(int i = 0;i<version1.length();++i)
{
if(version1.charAt(i)=='.')
index1[in1++] = i;
}
index1[in1] = version1.length(); int in2 = 1;
index2[0] = -1;
for(int i = 0;i<version2.length();++i)
{
if(version2.charAt(i)=='.')
index2[in2++] = i;
}
index2[in2] = version2.length(); //截取子串
int index = 0;
for(int i = 0;i<index1.length-1;i++)
{
arr1[index++] = version1.substring(index1[i]+1,index1[i+1]);
} index = 0;
for(int i = 0;i<index2.length-1;i++)
{
arr2[index++] = version2.substring(index2[i]+1,index2[i+1]);
}
int len1 = arr1.length;
int len2 = arr2.length;
int max = len1>len2?len1:len2;
//所有子串转化为整数形式
int num1[] = new int[max];
int num2[] = new int[max];
for(int i = 0;i<len1;i++)
num1[i] = Integer.parseInt(arr1[i]);
for(int i = 0;i<len2;i++)
num2[i] = Integer.parseInt(arr2[i]);
//长度不一,短的后面0补齐
/*
* *
* 例如1.0和1.0.0
* 前者生成的num1数组为[1,0]
* 后者生成的num2数组为[1,0,0]
* 这里将num1补齐为[1,0,0],便于比较
*/
if(len1>=len2)
{
for(int i = len2;i<len1;i++)
{
num2[i] = 0;
}
}
else
{
for(int i = len1;i<len2;i++)
{
num1[i] = 0;
}
}
/*for(int i = 0;i<num2.length;i++)
{
System.out.println(num2[i]);
} for(int i = 0;i<num1.length;i++)
{
System.out.println(num1[i]);
}*/
for(int i = 0;i<max;i++)
{
if(num1[i]>num2[i])
return 1;
if(num1[i]<num2[i])
return -1;
} return 0;
}

LeetCode_Compare Version Numbers的更多相关文章

  1. [LeetCode] Compare Version Numbers 版本比较

    Compare two version numbers version1 and version1.If version1 > version2 return 1, if version1 &l ...

  2. 【leetcode】Compare Version Numbers

    题目描述: Compare two version numbers version1 and version2. If version1 > version2 return 1, if vers ...

  3. Compare Version Numbers

    Compare two version numbers version1 and version1. If version1 > version2 return 1, if version1 & ...

  4. 【leetcode】Compare Version Numbers(middle)

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

  5. ✡ leetcode 165. Compare Version Numbers 比较两个字符串数字的大小 --------- java

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

  6. Java for LeetCode 165 Compare Version Numbers

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

  7. LeetCode Compare Version Numbers

    原题链接在这里:https://leetcode.com/problems/compare-version-numbers/ 用string.split()方法把原有string 从小数点拆成 str ...

  8. leetcode:Compare Version Numbers

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

  9. 【LeetCode】165 - Compare Version Numbers

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

随机推荐

  1. Django接受ajax传过来的数组

    $.ajax({ cache: false, type: "POST", url: "/userdelete/", traditional:true, //加上 ...

  2. linux内核对中断的处理方式

    中断取代了轮询的通知方式,DMA取代了轮询的读写数据方式. 分类软件指令造成的中断(又叫异常,同步中断).    svc, und, abt硬件通过中断请求信号造成的中断(异步中断).  irq,fi ...

  3. Spider Studio 新版本 (20140225) - 设置菜单调整 / 提供JQueryContext布局相关的方法

    这是年后的第一个新版本, 包含如下: 1. 先前去掉的浏览器设置功能又回来了! 说来惭愧, 去掉了这两个功能之后发现浏览经常会被JS错误打断, 很不方便, 于是乎又把它们给找回来了. :) 2. 为J ...

  4. 让浏览器下载文件http头部

    网站提供下载服务时经常需要实现一个强制下载功能(即强制弹出下载对话框),并且文件名保持和用户之前上传时相同. 效果如下图:  Content-Disposition 使用 HTTP Header 的 ...

  5. Lua中的常用语句结构以及函数

     1.Lua中的常用语句结构介绍 --if 语句结构,如下实例: gTable = {} ] ] then ]) == gTable[] then ]) else print("unkown ...

  6. 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法

    版权声明:本文为博主原创文章,未经博主允许不得转载. 在实际的应用中,我们常常需要实现在移动app和浏览器中点击返回.后退.上一页等按钮实现自己的关闭页面.调整到指定页面或执行一些其它操作的 需求,那 ...

  7. ASP.NET MVC 使用 Datatables (1)

    具体步骤: 1.建立实体类 public class Asset { public System.Guid AssetID { get; set; } [Display(Name = "Ba ...

  8. HashSet非常的消耗空间,TreeSet因为有排序功能,因此资源消耗非常的高,我们应该尽量少使用

    注:HashMap底层也是用数组,HashSet底层实际上也是HashMap,HashSet类中有HashMap属性(我们如何在API中查属性).HashSet实际上为(key.null)类型的Has ...

  9. Throw是一个语句,用来做抛出例外的功能

    当我们自己定义一个例外类的时候必须使其继承excepiton或者RuntimeException. Throw是一个语句,用来做抛出例外的功能. 而throws是表示如果下级方法中如果有例外抛出,那么 ...

  10. 程序员自己编写的类和JDK类是一种合作关系

    封装类: JAVA为每一个简单数据类型提供了一个封装类,使每个简单数据类型可以被Object来装载. 除了int和char,其余类型首字母大写即成封装类. 转换字符的方式: int I=10; Str ...