2019年11月4日随堂测试 最多输入字母统计
一、题目
二、源代码
import java.io.FileInputStream; import java.io.IOException; import java.io.InputStreamReader; import java.text.DecimalFormat; import java.util.ArrayList; import java.util.List; public class ReadWords { public static void main(String[] args)throws IOException { List<Integer> list=new ArrayList<>(); DecimalFormat df=new DecimalFormat("######0.00"); FileInputStream fip = new FileInputStream("C:\\\\\\\\Users\\\\26218\\\\Documents\\\\Tencent Files\\\\2621843759\\\\FileRecv\\\\Harry.txt"); InputStreamReader reader = new InputStreamReader(fip, "gbk"); StringBuffer sb = new StringBuffer(); while (reader.ready()) { sb.append((char) reader.read()); } reader.close(); fip.close(); int i; String A=sb.toString(); String M="abcdefghijklmnopqrstuvwxyz"; String temp = ""; char NUM[]=new char[A.length()]; char Z[]=new char[26]; int X[]=new int[26]; int MAX=0; Z=M.toCharArray(); for(int k=0;k<26;k++) { X[k]=0; for(i=0;i<A.length();i++) { NUM[i]=A.charAt(i); if(Z[k]==NUM[i]||Z[k]==ch(NUM[i])) { X[k]++; } } } double sum=0; for(i=0;i<25;i++) for(int k=0;k<25-i;k++) { if(X[k]<X[k+1]) { int temp2=X[k]; X[k]=X[k+1]; X[k+1]=temp2; char temp3=Z[k]; Z[k]=Z[k+1]; Z[k+1]=temp3; } } for(i=0;i<26;i++) { sum=sum+X[i]; } for(i=0;i<26;i++) { double jkl=(X[i])/sum*100; System.out.println(Z[i]+"字母个数为:"+X[i]+"字母频率为:"+df.format(jkl)+"%"); } } static char ch(char c) { if(!(c>=97&&c<=122)) c+=32; return c; } }
三、实验结果
四、心得体会
回过头来想这个程序的结构并不复杂,但是当时为什么会敲那么久还没有敲出来就说明了我代码的掌握程度还不够好,还需要加强练习才行。过程中我主要卡住的地方是文件的读写,字母数量的储存,排序还有最后顺序和相应字母的对应。前面几个问题还好,给我体会最深的就是最后一个问题,一开始写的时候我忘记了还要输出相应的字母,于是在过程中忘了和字母相对应,最后改代码的时候相当头疼。所以之后再写代码的时候一定要先想清楚,这段程序中需要什么样的变量,需要提前留出多少的空余,会有什么样的模块函数方法,如果将代码模块化,就会大大提高编程的效率,同时也会减少错误的出现,提高纠正BUG的效率。