lotus

贵有恒何必三更眠五更起 最无益只怕一日曝十日寒

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

1. 题目

 

 

 

 

2. 解法

 

 

思路

这道题的考点是字符串的处理和分割,以及整数的比较。解题思路是:

  • 首先,将两个版本号按照"."分割成字符串数组,这样就可以得到每个修订号的字符串表示。
  • 然后,遍历两个数组,比较每个位置上的修订号。为了方便比较,可以将字符串转换成整数,这样就可以忽略前导零的影响。
  • 如果某个数组已经遍历完了,就用0代替,这样就可以处理不同长度的版本号的情况。
  • 如果发现某个位置上的修订号不相等,就根据它们的大小返回相应的结果。
  • 如果遍历完了都没有发现不相等的情况,就返回0,表示两个版本号相等。

具体实现

 

class Solution {
    public int compareVersion(String version1, String version2) {
        // 将两个版本号按照"."分割成字符串数组
        String[] v1 = version1.split("\\.");
        String[] v2 = version2.split("\\.");
        // 获取两个数组的长度
        int len1 = v1.length;
        int len2 = v2.length;
        // 遍历两个数组,比较每个位置上的修订号
        for (int i = 0; i < Math.max(len1, len2); i++) {
            // 如果某个数组已经遍历完了,就用0代替
            int num1 = i < len1 ? Integer.parseInt(v1[i]) : 0;
            int num2 = i < len2 ? Integer.parseInt(v2[i]) : 0;
            // 比较两个数的大小
            if (num1 > num2) {
                return 1;
            } else if (num1 < num2) {
                return -1;
            }
        }
        // 如果都相等,就返回0
        return 0;
    }
}

  

3. 总结

posted on 2023-04-28 20:52  白露~  阅读(11)  评论(0编辑  收藏  举报