题解 | #字符串排序#
字符串排序
https://www.nowcoder.com/practice/5af18ba2eb45443aa91a11e848aa6723
import java.util.ArrayList; import java.util.Comparator; import java.util.Scanner; // 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); // 注意 hasNext 和 hasNextLine 的区别 int n = sc.nextInt(); ArrayList<String> list = new ArrayList<>(); for (int i = 0; i < n; i++) { list.add(sc.next()); } list.sort(new Comparator<String>() { @Override public int compare(String o1, String o2) { int n =Math.min(o1.length(),o2.length()); for (int i = 0; i < n; i++) { if (o1.charAt(i) != o2.charAt(i)) { return o1.charAt(i) - o2.charAt(i); } } return o1.length() - o2.length(); } }); for (String s : list) { System.out.println(s); } } }
两个没有在测试案例中体现出来的点:
1.不能去重,本来我都用treeset了,想偷懒来着;
2.大小写不同级,大写优先,我一开始还特地转为纯小写字串来比较,不过这个应该属于是常识性缺失吧。