• 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的效率。

  • 相关阅读:
    kbmMW 5.07.00试用笔记
    在 Andriod/IOS 程序中使用自定义字体
    【转】Delphi 10.3关于相机该注意的细节
    Delphi 10.3终于来了
    REST easy with kbmMW #17 – Database 6 – Existing databases
    【go】1环境搭建go语言介绍
    【ESSD技术解读02】企业级利器,阿里云 NVMe 盘和共享存储
    项目实战总结以及接入UAPM
    RocketMQ 5.0 POP 消费模式探秘
    Cube 技术解读 | 详解「支付宝」全新的卡片技术栈
  • 原文地址:https://www.cnblogs.com/suanai/p/11801216.html
Copyright © 2020-2023  润新知