集册 Java实例教程 Java集合创建Anagrams算法

Java集合创建Anagrams算法

欢马劈雪     最近更新时间:2020-01-02 10:19:05

467
Java集合创建Anagrams算法

import java.util.*;

import java.io.*;
/* from 
时代Java公众号 - nowjava.com*/


public class Anagrams2 {

    public static void main(String[] args) {

        int minGroupSize = Integer.parseInt(args[1]);


        // Read words from file and put into simulated multimap

        Map<String, List<String>> m = new HashMap<String, List<String>>();

        try {

            Scanner s = new Scanner(new File(args[0]));

            while (s.hasNext()) {

                String word = s.next();

                String alpha = alphabetize(word);/** 来 自 nowjava - 时代Java**/

                List<String> l = m.get(alpha);

                if (l == null)

                    m.put(alpha, l = new ArrayList<String>());

                l.add(word);

            }

        } catch (IOException e) {

            System.err.println(e);

            System.exit(1);

        }


        // Make a List of all permutation groups above size threshold

        List<List<String>> winners = new ArrayList<List<String>>();

        for (List<String> l : m.values())

            if (l.size() >= minGroupSize)

                winners.add(l);


        // Sort permutation groups according to size

        Collections.sort(winners, new Comparator<List<String>>() {

            public int compare(List<String> o1, List<String> o2) {

                return o2.size() - o1.size();

            }

        });


        // Print permutation groups

        for (List<String> l : winners) {

            System.out.println(l.size() + ": " + l);

        }

    }


    private static String alphabetize(String s) {

        char[] a = s.toCharArray();

        Arrays.sort(a);

        return new String(a);

    }

}


展开阅读全文