找出字符串中重複字符

package javaBasic;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

/**
 * 
 * Java Program to find duplicate characters in String.
 * 
 * 
 * 
 * 
 * 
 * @author http://java67.blogspot.com
 */

public class FindDuplicateCharacters {

    public static void main(String args[]) {

        printDuplicateCharacters("Programming");

        printDuplicateCharacters("Combination");

        printDuplicateCharacters("Java");

    }

    /*
     * 
     * Find all duplicate characters in a String and print each of them.
     */

    public static void printDuplicateCharacters(String word) {

        char[] characters = word.toCharArray();

        // build HashMap with character and number of times they appear in
        // String

        Map<Character, Integer> charMap = new HashMap<Character, Integer>();

        for (Character ch : characters) {

            if (charMap.containsKey(ch)) {

                charMap.put(ch, charMap.get(ch) + 1);

            } else {

                charMap.put(ch, 1);

            }

        }

        // Iterate through HashMap to print all duplicate characters of String

        Set<Map.Entry<Character, Integer>> entrySet = charMap.entrySet();

        System.out.printf("List of duplicate characters in String '%s' %n",
                word);

        for (Map.Entry<Character, Integer> entry : entrySet) {

            if (entry.getValue() > 1) {

                System.out.printf("%s : %d %n", entry.getKey(), entry
                        .getValue());

            }

        }

    }

}
相關文章
相關標籤/搜索