比较版本号

此题可采用双指针的的解法。

 public int compare (String version1, String version2) {
        // write code here
        int n1=version1.length(),n2=version2.length(),len1=0,len2=0;
        while (len1<n1&&len2<n2){
            int num1=0,num2=0;
            while (len1<n1&&version1.charAt(len1)!='.'){
                num1=num1*10+(version1.charAt(len1++)-'0');
            }
            while (len2<n2&&version2.charAt(len2)!='.'){
                num2=num2*10+(version2.charAt(len2++)-'0');
            }

            if (num1>num2){
                return 1;
            }else if(num2>num1){
                return -1;
            }
            len1++;
            len2++;
        }
        return 0;
    }


全部评论

相关推荐

2025-12-19 21:53
门头沟学院 Java
想做OpenGL:不要一来就把自己定位这么低吧,把大厂当成目标,不断去学技术做项目,最后你至少能学到能找到中小厂的技术水平,你一上来就找这种两千块还要前后端都会的,其实对你用处不会很大,真去了也是打杂
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务