Java文件写入与读取实例求最大子数组
出现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文件写入与读取实例求最大子数组的更多相关文章
- JAVA文件写入FileWriter
JAVA文件写入FileWriter 导包import java.io.FileWriter创建构造方法public FileWrite(String filename),参数是文件的路径及文件名(默 ...
- [LeetCode] Maximum Product Subarray 求最大子数组乘积
Find the contiguous subarray within an array (containing at least one number) which has the largest ...
- [LeetCode] 152. Maximum Product Subarray 求最大子数组乘积
Given an integer array nums, find the contiguous subarray within an array (containing at least one n ...
- java 文件及流读取
在Java语言的IO编程中,读取文件是分两个步骤:1.将文件中的数据转换为流,2.读取流内部的数据.其中第一个步骤由系统完成,只需要创建对应的流对象即可,对象创建完成以后步骤1就完成了,第二个步骤使用 ...
- 面试题之——将文件夹下java文件写入到新的文件夹,并修改扩展名
题目:将d:/code/java文件夹下的所有.java文件复制到d:/code/java/jad文件夹下并且将原来的文件的扩展名.java改为.jad 源代码: package com.zyh.in ...
- Java文件写入,换行
import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOExce ...
- Python学习笔记——文件写入和读取
1.文件写入 #coding:utf-8 #!/usr/bin/env python 'makeTextPyhton.py -- create text file' import os ls = os ...
- java文件写入和读出的序列化
文件的写入入与读出都有它们自己的格式,不便于读入和取出,implement Serializable接口,实现任何个事文件的写入和读取取:
- 【PHP】文件写入和读取详解
文章提纲: 一.实现文件读取和写入的基本思路 二.使用fopen方法打开文件 三.文件读取和文件写入操作 四.使用fclose方法关闭文件 五.文件指针的移动 六.Windows和UNIX下的回车和换 ...
随机推荐
- 8款基于Jquery的WEB前端动画特效
1.超炫酷的30个jQuery按钮悬停动画 按钮插件是最常见的jQuery插件之一,因为它用途广泛,而且配置起来最为方便.今天我们要分享的是30个超炫酷的jQuery悬停按钮动画,当我们将鼠标滑过按钮 ...
- idea 使用正则表达式 进行匹配替换
关于正则表达式 可以参考相应的笔记 另外 如果要提取正则表达式中匹配到的内容,使用$1 - $... 按顺序取(第一个表达式 到 第N个表达式匹配到的数据), 这点和linux正则获取的方式是一样的
- 【GMT43智能液晶模块】例程十三:FATFS实验——文件操作
实验原理: STM32F429上带有SDIO控制器,GMT43液晶模块上将SDIO连接到TF卡座.本实验 将Micro SD卡插入TF卡座上即可.通过FATFS创建test.txt文件,并且写入数据0 ...
- sql日期格式小应用 记录一下
比如这样的数据 20170317 要转成2017-03-17 单独一步做不到 两步思想 先转成日期格式 在进行格式化 select CONVERT(varchar(10),(CAST(CONVERT( ...
- swoole Tcp服务器
基础代码 <?php //创建Server对象,监听 127.0.0.1:9501端口 $serv = ); //监听连接进入事件 $serv->on('connect', functio ...
- CSS面试题
1.有哪些方式可以对一个DOM设置它的CSS样式? 外部样式表.引入一个外部CSS文件: 内部样式表.将CSS代码放在<head>标签内部: 内联样式,将CSS样式直接定义在HTML元素内 ...
- CentOS上安装配置Ruby on Rails
0.install sublime editor(optional) ref:http://www.tecmint.com/install-sublime-text-editor-in-linux/ ...
- 真-关闭win10安全中心(windows defender)
狂客原创,转载请注明.侵权必究 第一 任务管理器 启动项 禁用 第二 使用win+R,打开运行命令输入:gpedit.msc然后点击确定 在管理模块下找到Windows组件,接续打开下拉菜单,找到Wi ...
- Qt编写自定义控件6-指南针仪表盘
前言 指南针仪表盘,主要用来指示东南西北四个方位,双向对称两个指针旋转,其实就是360度打转,功能属于简单型,可能指针的绘制稍微难一点,需要计算多个点构成多边形,本系列控件文章将会连续发100+篇,一 ...
- SimpleDateFormat 出现错误 Call requires API level 24 (current min is 15)
这个故事是这样的 今天写打卡时间的时候需要获取一下当前时间,然后我就写了一个这个 SimpleDateFormat sDF = new SimpleDateFormat("yyyy-MM ...