zoukankan      html  css  js  c++  java
  • 数组(续)

       题目:数组元素从文件中读取。

       要求:数字很多和很大,也能正常输出(考虑数的溢出),输入文件参数有错误,程序能正常退出,并显示相应的错误信息。任何输入错误都不能导致程序崩溃。

       思路:在文件读取getfile函数中规范文件的格式;在selectArray函数中进行数组的运算,类似于前面的数组运算;在FindArrayList函数进行文件的读取,并处理读取到的信息,然后在主函数中调用这个函数,就能实现文件中信息进行数组的运算。

    import java.util.Scanner;
    public class shuzu3 {
        public static void main(String[] args) {
            //"C:\Users\Administrator\Desktop\kkk.txt"
            //判断文件路径输入是否正确
            FindArrayList(getfile());
        }
        private static BigInteger FindArrayList(File file) {
            ArrayList<String> arrayList = new ArrayList<>();
            try {
                InputStreamReader input = new InputStreamReader(new FileInputStream(file));
                BufferedReader bf = new BufferedReader(input);
                // 按行读取字符串
                String str;
                while ((str = bf.readLine()) != null) {
                    arrayList.add(str);
                }
                bf.close();
                input.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            // 对ArrayList中存储的字符串进行处理
            int count=0;
            int count2=0;
            ArrayList<String> number = new ArrayList<>();
            int length = arrayList.size();
            for (int i = 0; i < length; i++) {
              String [] s = arrayList.get(i).split(" ");
              int width=s.length;
              for(int j=0;j<width;j++) {
                  if(!s[j].equals("")&&s[j].matches("^-?\d+$")) {
                  number.add(s[j]);
                  count++;
                  }
                  count2++;
              }              
            }
            System.out.println("本次共识别"+count+"个数据;有"+(count2-count)+"个非数字数据不能识别");
            int numbersize=number.size();
            BigInteger q=new BigInteger("-99999999999999999999999999999999999999999999");  
            for(int i=1;i<numbersize;i++) {
                ArrayList<String> newNumber=new ArrayList<String>();
               for(int j=0;j<number.size();j++) {
                   newNumber.add(number.get((i+j)%numbersize));
               }
                q= max(selectArray(newNumber),q);
             }
                 System.out.println(q);
           return q;
        }
        public static BigInteger selectArray(ArrayList<String> number) {
            BigInteger ans=new BigInteger((String)number.get(0));
            for(int i = 1;i < number.size(); i++){
               BigInteger big1=new BigInteger((String)number.get(i));
               BigInteger big2=new BigInteger((String)number.get(i-1));
               BigInteger big3=big1.add(big2);
               if(big3.compareTo(big1)>=0) {
                   number.set(i, big3.toString());     
                 }     
                }
            for(int i=0;i<number.size();i++) {
                BigInteger big=new BigInteger((String)number.get(i));
                ans=max(ans,big);
            }
            return ans;
        }
        private static BigInteger max(BigInteger big1, BigInteger ans) {
            // TODO Auto-generated method stub
            if(big1.compareTo(ans)>=0) {
                return big1;
            }
            else return ans;  
        }
        public static File getfile() {
               System.out.println("请输入文件路径");
               Scanner sc=new Scanner(System.in);
               while(true) {
               String line=sc.nextLine();
               File kk=new File(line);
               if(!kk.isFile()) {
                   System.out.println("输入的不是文件路径,请重新输入");
               }
               else if(kk.isFile()) {
                   return kk;
               }
        }
        }
    }
  • 相关阅读:
    面向接口编程详解(二)——编程实例
    面向接口编程详解(一)——思想基础
    设计模式之面向接口编程
    EF数据注解
    很多人不知道可以使用这种 key 的方式来对 Vue 组件时行重新渲染
    这是最新的一波Vue实战技巧,不用则已,一用惊人
    Node.js 进阶-你应该知道的 npm 知识都在这
    Vue响应式原理
    eslint规则
    简述vue-cli中chainWebpack的使用方法
  • 原文地址:https://www.cnblogs.com/fengjingfei/p/12374873.html
Copyright © 2011-2022 走看看