集合练习
编写一个程序,从标准输入设备上输入一行英文语句。敲击回车后对该语句进行分析,统计除逗号,句号,感叹号和问号以外的所有单词的频次并打印在标准输出设备上。输出顺序按Java语言的字符串的自然顺序排序。
字符串自然顺序是指,对字符串从左到右,每个字符按照其字符的ascii码从小到大排序,如果第1个字符相同,则比较第二个字符,然后以此类推。
资料:
举例一:
输入:
输出:
代码如下:
import java.util.Iterator;
import java.util.Scanner;
import java.util.TreeMap;
public class D0017 {
public static String StatList(String str) {
StringBuffer sb = new StringBuffer();
TreeMap<String ,Integer> has = new TreeMap<String ,Integer> ();
//切开的时候把连续符号也带入引发错误
String[] slist= str.split("\\? |\\, |\\. |\\! | |,|\\?|\\.|\\!|\\....");//"\\s|(?<!\\d)[,.]|[,.](?!\\d)|\\. |\\! ");//");
for (int i = 0; i < slist.length; i++) {
if (!has.containsKey(slist[i])) {
has.put(slist[i], 1);
} else {
has.put(slist[i],has.get(slist[i])+1 );
}
}
Iterator<String> iterator = has.keySet().iterator();
int on=0;
while(iterator.hasNext()){
String word = (String) iterator.next();
if(on>=0){
sb.append(word).append(",").append(has.get(word));
if(iterator.hasNext())sb.append("\n");
}
on++;
}
return sb.toString();
}
public static void main(String[] args){
Scanner input=new Scanner(System.in);
String str=input.nextLine();
System.out.print(StatList(str));
}
}
(全文完)