前一段时间,碰到了一个题:对给出的一系列英文单词按首字母进行排序,并输出排序后的结果。
这道题困扰了我挺长一段时间,我想的实现方法都是比较麻烦的,比如先把每个单词的都字母提出来比较它们的大小,再排序。但里面存在着许多的问题,像大小写字母的不同啊,首字母一样的怎么办啊…
直到学习了的关于String字符串的方法才很好的解决了这个问题。
在String中这样一个方法compareToIgnoreCase()它是忽略大小写的比较两个单词在字典中的顺序。通过使用这个方法,很容易就可以解决这个问题。
下面是我写的代码:
import java.util.Scanner;/** 请对给出的一系列英文单词按首字母进行排序,并输出排序后的结果。输入说明:数字N,表明单词数,接下来是N个英文单词;输出说明:按字母序的排序结果。输入样例:6Apple banana Zebra Tuesday moon CAN输出样例:ApplebananaCAN moon Tuesday Zebra*/
public class Sort {public static void main(String[] args) {Scanner input = new Scanner(System.in);System.out.println("请输入单词的个数:");int num = input.nextInt();String[] strArr = new String[num];System.out.println("请输入单词:");for(int i = 0;i < strArr.length;i++) {strArr[i] = input.next();}//将键盘输入的单词输入到String数组中wordSort(strArr);}public static void wordSort(String[] strArr) {//比较单词字典顺序 用冒泡排序法比较for(int i = strArr.length - 1;i > 0;i--) {for(int j = 0;j < i;j++) { if(strArr[j].compareToIgnoreCase(strArr[j + 1]) > 0) {String temp = strArr[j];strArr[j] = strArr[j + 1];strArr[j + 1] = temp;}}}for(String i : strArr) {System.out.println(i);}
}
}
下面是输出结果:
通过这个事情,我们要明白在编写一个程序的时候可以现在API中找一下看看Java有没有给我们提供了一些相关的方法,如果有的话将会大大降低我们编写代码的难度和复杂度。API对我们的作用是很大的,我们一定要提高对其的熟悉程度。