迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中按字母顺序比较字符串

作者:迹忆客 最近更新:2023/03/26 浏览次数:

在 Java 中有多种方法可以比较两个或多个字符串,但如果你想按字典顺序(按字母顺序)比较字符串,请参阅这篇文章。字典顺序遵循字典中的单词排列。下面的示例展示了在 Java 中按字母顺序比较字符串的两种方法。


使用 compareTo() 按字母顺序比较字符串

在示例中,我们比较了几个字符串以查看结果是否正确。compareTo() 方法带有 String 类,因此我们可以用任何字符串调用它来与另一个字符串进行比较。下面我们将 s1s2s3s4s5s6 等进行比较。

当我们使用 compareTo() 比较字符串时,该方法返回一个 int 值,该值告诉我们字符串应该放在之前或之后的位置,或者它们是否相等。例如,如果我们使用 s1.compare(s2) 将值为 apples1 与值为 oranges2 进行比较,则 comparedResult 函数将得到一个负整数——这意味着 s1 值在 s2 之前。

如果 comparedResult 得到一个正整数,当 s3s4 进行比较时,这意味着 s3s4 之后,因为按字典顺序,大写字母在小写字母之前。

如果 compareTo() 方法返回零,则表示两个比较的字符串相等,如 s9s10

class CompareStrings {
    public static void main(String args[]) {
        String s1 = "apple";
        String s2 = "orange";
        compareStrings(s1, s2);
        String s3 = "apple";
        String s4 = "Orange";
        compareStrings(s3, s4);
        String s5 = "sole";
        String s6 = "soul";
        compareStrings(s5, s6);
        String s7 = "john";
        String s8 = "johnson";
        compareStrings(s7, s8);
        String s9 = "one";
        String s10 = "one";
        compareStrings(s9, s10);

    }

    public static void compareStrings(String s1, String s2) {

        int comparedResult = s1.compareTo(s2);

        if (comparedResult > 0) {
            System.out.println(s1 + " comes after " + s2);
        } else if (comparedResult < 0) {
            System.out.println(s1 + " comes before " + s2);
        } else {
            System.out.println(s1 + " is equal to " + s2);
        }


    }
}

输出:

apple comes before orange
apple comes after Orange
sole comes before soul
john comes before johnson
one is equal to one

使用传统方式按字母顺序比较字符串

在这个例子中,我们采用与前面的例子相同的输出相同的字符串,但方法不同。我们不使用任何类的方法,而是创建自己的方法。compareStrings() 是进行比较的方法。

compareStrings() 中,我们创建了一个循环,检查直到字符串 s1s2 的结尾。在循环内部,我们首先使用 charAt() 获取字符串的字符并将其转换为 int,这将返回一个 ASCII 值。我们对两个字符串都这样做,然后比较 ASCII 值。如果所有 ASCII 值都相等,则意味着两个字符串也相等。

如果 ASCII 值不同,那么我们使用 (int) s1.charAt(i) - (int) s2.charAt(i); 返回字符串的 ASCII 值之间的差异。在循环之后,我们检查字符串的长度,然后返回它们之间的差异。

最后,获取 compareStrings() 方法返回的 int 值并将其与字符串一起传递给 getComparisonResult() 函数,该函数打印结果是字符串应该在前面还是后面,或者它们是否是平等的。

class CompareStrings {
    public static void main(String[] args) {
        
        String s1 = "apple";
        String s2 = "orange";
        int getValue1 = compareStrings(s1, s2);
        
        String s3 = "apple";
        String s4 = "Orange";
        int getValue2 = compareStrings(s3, s4);
        
        String s5 = "sole";
        String s6 = "soul";
        int getValue3 = compareStrings(s5, s6);
        
        String s7 = "john";
        String s8 = "johnson";
        int getValue4 = compareStrings(s7, s8);
        
        String s9 = "one";
        String s10 = "one";
        int getValue5 = compareStrings(s9, s10);

        getComparisonResult(getValue1, s1, s2);
        getComparisonResult(getValue2, s3, s4);
        getComparisonResult(getValue3, s5, s6);
        getComparisonResult(getValue4, s7, s8);
        getComparisonResult(getValue5, s9, s10);
        
    }

    public static int compareStrings(String s1, String s2) {

        for (int i = 0; i < s1.length() && i < s2.length(); i++) {
            if ((int) s1.charAt(i) == (int) s2.charAt(i)) {
                continue;
            } else {
                return (int) s1.charAt(i) - (int) s2.charAt(i);
            }
        }

        if (s1.length() < s2.length()) {
            return (s1.length() - s2.length());
        } else if (s1.length() > s2.length()) {
            return (s1.length() - s2.length());
        } else {
            return 0;
        }
    }

    private static void getComparisonResult(int value, String s1, String s2) {
        if (value > 0) {
            System.out.println(s1 + " comes after " + s2);
        } else if (value < 0) {
            System.out.println(s1 + " comes before " + s2);
        } else {
            System.out.println(s1 + " and " + s2 + " are equal");
        }
    }
}

输出:

apple comes before orange
apple comes after Orange
sole comes before soul
john comes before johnson
one and one are equal

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 Java 中获取文件大小

发布时间:2023/05/01 浏览次数:139 分类:Java

Java 提供了不同的方法来获取文件的字节大小。 本教程演示了在 Java 中获取文件大小的不同方法。使用 Java IO 的文件类获取文件大小 Java IO 包的 File 类提供了以字节为单位获取文件大小的功能。

Java 中的文件分隔符

发布时间:2023/05/01 浏览次数:108 分类:Java

本篇文章介绍了 Java 中的文件分隔符。Java 中的文件分隔符 文件分隔符是用来分隔目录的字符; 例如,Unix 使用 /,Windows 使用 \ 作为文件分隔符。

Java 中的文件过滤器

发布时间:2023/05/01 浏览次数:193 分类:Java

本篇文章介绍如何在 Java 中使用 FileFilter。FileFilter 用于过滤具有特定扩展名的文件。 Java内置包IO和Apache Commons IO为FileFilter提供了类和接口来进行文件过滤操作。

Java 获取 ISO 8601 格式的当前时间戳

发布时间:2023/05/01 浏览次数:132 分类:Java

本篇文章介绍了 ISO 8601 日期格式、其重要性及其在 Java 中的使用。 它还列出了一些优点来强调为什么应该使用 ISO 格式来表示日期。

在 Java 中获取数组的子集

发布时间:2023/05/01 浏览次数:142 分类:Java

本篇文章介绍了几种在 Java 中获取数组子集的方法。使用 Arrays.copyOf() 方法获取数组的子集 使用 Arrays.copyOfRange() 方法获取数组的子集

用 Java 填充二维数组

发布时间:2023/05/01 浏览次数:110 分类:Java

二维数组是基于表结构的,即行和列,填充二维数组不能通过简单的添加到数组操作来完成。 本篇文章介绍如何在 Java 中填充二维数组。

Java 中的自然排序

发布时间:2023/05/01 浏览次数:132 分类:Java

Java 中最常用的顺序是自然顺序。 本文将展示如何使用 naturalOrder() 函数对数组进行排序。

计算 Java 数组中的重复元素

发布时间:2023/05/01 浏览次数:202 分类:Java

本篇文章介绍Java计算数组中重复元素的方法。计算 Java 数组中的重复元素。我们可以创建一个程序来计算数组中的重复元素。 该数组可以是未排序的,也可以是已排序的。

Java 中 List 和 Arraylist 的区别

发布时间:2023/05/01 浏览次数:90 分类:Java

表示为单个单元的一组单个对象称为集合。 在 Java 中,Collection 是一个具有多个已定义接口和类的框架,用于将一组对象表示为一个单元。 它允许我们操纵

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便