importer java.util.ArrayList ;
importer java.util.Collections ;
importer java.util.HashMap ;
importer java.util.List ;
importer java.util.Map ;
classe publique WordsStatistics {
classe Obj {
nombre int ;
Obj(int compte){
this.count = nombre ;
}
}
statistiques de liste publique <WordCount> (mot de chaîne) {
List<WordCount> rs = new ArrayList<WordCount>();
Map <String,Obj> map = new HashMap<String,Obj>();
si (mot == null ) {
renvoie null ;
}
mot = mot.toLowerCase();
word = word.replaceAll("'s", "");
mot = mot.replaceAll(",", "");
mot = mot.replaceAll("-", "");
mot = mot.replaceAll("//.", "");
mot = mot.replaceAll("'", "");
mot = mot.replaceAll(":", "");
word = word.replaceAll("!", "");
mot = mot.replaceAll("/n", "");
Chaîne [] wordArray = word.split(" ");
pour (String simpleWord : wordArray) {
simpleWord = simpleWord.trim();
if (simpleWord != null && !simpleWord.equalsIgnoreCase("")) {
Obj cnt = map.get(simpleWord);
si ( cnt!= null ) {
cnt.count++;
}autre {
map.put(simpleWord, new Obj(1));
}
}
}
pour (clé de chaîne : map.keySet()) {
WordCount wd = new WordCount(key,map.get(key).count);
rs.add(wd);
}
Collections.sort(rs, nouveau java.util.Comparator<WordCount>(){
@Outrepasser
public int comparer (WordCount o1, WordCount o2) {
int résultat = 0 ;
si (o1.getCount() > o2.getCount() ) {
résultat = -1 ;
} sinon si (o1.getCount() < o2.getCount()) {
résultat = 1 ;
}autre {
int strRs = o1.getWord().compareToIgnoreCase(o2.getWord());
si ( strRs > 0 ) {
résultat = 1 ;
}autre {
résultat = -1 ;
}
}
renvoyer le résultat ;
}
});
retourner rs;
}
public static void main(String args[]) {
String word = "Pinterest est peut-être le rêve d'un spécialiste du marketing - ce site est largement utilisé pour sélectionner des produits" ;
MotsStatistiques s = new MotsStatistiques();
Liste<WordCount> rs = s.statistics(word);
pour (WordCount mot1 : rs) {
System.out.println(word1.getWord()+"*"+word1.getCount());
}
}
}