出现bug的点:输入数组无限大;

输入的整数,量大:

解决方案:向文件中输入随机数组,大小范围与量都可以控制。

源代码:

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Random;
public class XieRuDuQu {
 public static void main(String[] args)  throws IOException{
  writeRandomByOutputStreamWriter("D:\\data.txt");
        System.out.println("最大子数组:"+max(readArrayByInputStreamReader("D:\\data.txt")));//输出最大子数组
    }
 
 public static int max(int a[]) {
  /**
   * 求一维数组最大子数组
   */
  int x=a.length;
  int b[][]=new int[x][x];//存子数组
  int c[]=new int[x];//存二维数组每一行的最大值
  for(int i=0;i<x;i++) {//所有子数组存入二维数组中:以第i个开头的子数组们存入第i行
   for(int j=0;j<x;j++) {//求出二维数组的一行
    int sum=0;
    for(int s=i;s<=j;s++){//求每一个子数组    
    sum+=a[s];
    }
    b[i][j]=sum;//存子数组
   }
  };  
  for(int i=0;i<x;i++) {//i为行   
   for(int j=0;j<x;j++) {//j为列
       if(b[i][j]>c[i]) {    
        c[i]=b[i][j];
       }
   }
  }
  int s=0;
  for(int i=0;i<c.length;i++) { 
   
   if(s<c[i]) {
    s=c[i];
   }
  };
  return s;
    }
 public static int[] readArrayByInputStreamReader(String txt) {
  /**
   *读取
   */        
  ArrayList<String> arrayList = new ArrayList<>();
  try {
   String encoding = "UTF-8";
      File file = new File(txt);
      InputStreamReader read = new InputStreamReader(new FileInputStream(file), encoding);    
   BufferedReader bufferedReader = new BufferedReader(read);
   if (file.isFile() && file.exists()) {        
    String temp;   
    while ((temp = bufferedReader.readLine()) != null) { 
     arrayList.add(temp);              
     }
    bufferedReader.close();
    read.close();    
   }
  }catch (Exception e) {       
   e.printStackTrace();  
  }
   // 对ArrayList中存储的字符串进行处理  
        int length = arrayList.size();  
        int[] array = new int[length];  
        for (int i = 0; i < length; i++) {   
        String s = arrayList.get(i);   
        array[i] = Integer.parseInt(s);  
        } 
  return array;
 }
 public static void writeRandomByOutputStreamWriter(String txt) {
  /**
    * 文件写入随机数    
       */
       try {
      String encoding = "UTF-8"; 
   File file = new File(txt);       
           if(!file.exists()) 
           {   //如果不存在data.txt文件则创建 
               file.createNewFile(); 
               System.out.println("文件创建完成");              
           } 
           OutputStreamWriter write = new OutputStreamWriter(new FileOutputStream(file), encoding);    
   BufferedWriter bufferedWriter = new BufferedWriter(write);
           //产生随机数据,写入文件 
           Random random = new Random(); 
           for(int i=0;i<10;i++) 
           {    
               int randint =(int)Math.floor((random.nextDouble()*100.0));   //产生0-10000之间随机数         
               bufferedWriter.write(String.valueOf(randint));      //写入一个随机数 
               bufferedWriter.newLine();       //新的一行 
           } 
           bufferedWriter.close();
           write.flush();
           write.close(); 
  
     
     }catch (Exception e) {       
    e.printStackTrace();  
   }
           
 }
}

文档:

运行结果:

Java文件写入与读取实例求最大子数组的更多相关文章

  1. JAVA文件写入FileWriter

    JAVA文件写入FileWriter 导包import java.io.FileWriter创建构造方法public FileWrite(String filename),参数是文件的路径及文件名(默 ...

  2. [LeetCode] Maximum Product Subarray 求最大子数组乘积

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  3. [LeetCode] 152. Maximum Product Subarray 求最大子数组乘积

    Given an integer array nums, find the contiguous subarray within an array (containing at least one n ...

  4. java 文件及流读取

    在Java语言的IO编程中,读取文件是分两个步骤:1.将文件中的数据转换为流,2.读取流内部的数据.其中第一个步骤由系统完成,只需要创建对应的流对象即可,对象创建完成以后步骤1就完成了,第二个步骤使用 ...

  5. 面试题之——将文件夹下java文件写入到新的文件夹,并修改扩展名

    题目:将d:/code/java文件夹下的所有.java文件复制到d:/code/java/jad文件夹下并且将原来的文件的扩展名.java改为.jad 源代码: package com.zyh.in ...

  6. Java文件写入,换行

    import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOExce ...

  7. Python学习笔记——文件写入和读取

    1.文件写入 #coding:utf-8 #!/usr/bin/env python 'makeTextPyhton.py -- create text file' import os ls = os ...

  8. java文件写入和读出的序列化

    文件的写入入与读出都有它们自己的格式,不便于读入和取出,implement Serializable接口,实现任何个事文件的写入和读取取:

  9. 【PHP】文件写入和读取详解

    文章提纲: 一.实现文件读取和写入的基本思路 二.使用fopen方法打开文件 三.文件读取和文件写入操作 四.使用fclose方法关闭文件 五.文件指针的移动 六.Windows和UNIX下的回车和换 ...

随机推荐

  1. 微信小程序——购物车结算

    项目需要做个购物车结算功能,先分析需求: 1.全选,反选的功能.当选中的个数 = 购物车的数量时,勾选全选按钮,反之则取消选中全选按钮: 2.改变选中状态时,计算总价和总数量: 3.单个产品的数量加减 ...

  2. Centos&Redhat下bcm43142博通无线网卡linux驱动之二

    上次通过更换内核实现成功编译驱动无线网卡,但是启动到系统原内核下依然没有bcm43142的驱动,遂准备在原内核下编译驱动,记录一下 ps:更推荐这种方法,避免因更换内核出现其他兼容性问题 1.准备驱动 ...

  3. java.lang.NoClassDefFoundError: javax/annotation/Priority

    异常内容: 2017-09-25-15-02 [localhost-startStop-1] [org.springframework.web.context.ContextLoader] [ERRO ...

  4. macOS Sierra 如何卸载.net core 版本

    由于目前没有找到一个合适的办法,将本机.NET Core的版本升级到1.1,故只有先卸载再安装最新版本了. 卸载脚本链接为:https://github.com/dotnet/cli/blob/rel ...

  5. git log --pretty=format:" "

    控制显示的记录格式,常用的格式占位符写法及其代表的意义如下: 选项 说明%H   提交对象(commit)的完整哈希字串%h    提交对象的简短哈希字串%T    树对象(tree)的完整哈希字串% ...

  6. dir 命令手册

    dir 命令手册 参数 /A D 目录 R 只读文件 H 隐藏文件 A 准备存档的文件 S 系统文件 - 表示"否"的前缀 /B 使用空格式(没有标题信息或摘要) /C 在文件大小 ...

  7. Relation Extraction中SVM分类样例unbalance data问题解决 -松弛变量与惩罚因子

    转载自:http://blog.csdn.net/yangliuy/article/details/8152390 1.问题描述 做关系抽取就是要从产品评论中抽取出描述产品特征项的target短语以及 ...

  8. iOS WKWebView (NSURLProtocol)拦截js、css,图片资源

    项目地址github:<a href="https://github.com/LiuShuoyu/HybirdWKWebVIew/">HybirdWKWebVIew&l ...

  9. centos 安装python PIL模块

    转载:https://www.cnblogs.com/ccdc/p/4069112.html 1.安装 使用yum安装缺少类库: #尤其重要,否则会报错 yum install python-deve ...

  10. D - Nearest Common Ancestors

    A rooted tree is a well-known data structure in computer science and engineering. An example is show ...