JAVA基础(TreeSet按字母进行排序)

1,需求

  • 从键盘接收一个字符串, 程序对其中所有字符进行排序,例如键盘输入: helloitcast程序打印:acehillostt

 

2,分析:

  • 键盘录入字符串,Scanner

  • 将字符串转换为字符数组

  • 定义TreeSet集合,传入比较器对字符排序并保留重复

  • 遍历字符数组,将每一个字符存储在TreeSet集合中

  • 遍历TreeSet集合,打印每一个字符


 

import java.util.Comparator;

import java.util.Scanner;

import java.util.TreeSet;

public class Test5 {

    public static void main(String[] args) {

        //1,键盘录入字符串,Scanner

        Scanner sc = new Scanner(System.in);

        System.out.println("请输入一个字符串");

        String line = sc.nextLine();

        //2,将字符串转换为字符数组

        char[] arr = line.toCharArray();

        //3,定义TreeSet集合,传入比较器对字符排序并保留重复

        TreeSet<Character> ts = new TreeSet<>(new Comparator<Character>() {





            @Override

            public int compare(Character c1, Character c2) {

                //int num = c1 - c2;                //自动拆箱

                int num = c1.compareTo(c2);

                return num == 0 ? 1 : num;

            }

        });

        

        //4,遍历字符数组,将每一个字符存储在TreeSet集合中

        for(char c : arr) {

            ts.add(c);                            //自动装箱

        }

        

        //5,遍历TreeSet集合,打印每一个字符

        for(Character c : ts) {

            System.out.print(c);

        }

    }





}

 

 

上一篇:HashSet 与TreeSet和LinkedHashSet的区别


下一篇:蓝桥 算法训练 明明的随机数