Java实验——输出一个数组里面连续子数组最大的和(二)文件操作
在本周的练习中,主要是对上周的实验进行健壮性的完善,即在所能考虑到的情况之中,尽量使自己的程序能够正常地运行。
在上周的实验中,我已经是在编程过程中考虑到用户输入的错误类型的问题,所以这一方面并没有多大的阻碍,最大的问题是没有考虑到数值的大小对最终结果的影响,所定义的存储和的变量用的是int型,这样导致了如果输入的结果过大的话,就可能导致变量的值溢出的情况,根据系统库中提供的biginteger类,提供了大数整型的处理,所以只需要对其中的int类型修改成相应的biginteger操作即可。
然后在本次练习之中要求:要对文件里面的内容进行读取再进行操作。由于考虑到健壮性,我决定在遇到类似于字符这一类数据的情况就对文件停止读取操作,根据正则表达式对其进行判断。并输出相应的错误原因。
根据上面的实现思想,我根据上周的代码修改写出了以下的代码:
package lainxu; import java.io.BufferedReader;
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.math.BigInteger;
import java.util.List;
//import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern; public class ShowM { //static Scanner it=new Scanner(System.in);
static List<BigInteger> nums=new ArrayList<BigInteger>(); //用于储存数组
public static void main(String[] args) throws IOException {
// TODO 自动生成的方法存根 List<BigInteger> max=new ArrayList<BigInteger>(); int maxp=-1; //储存从1开始的子组和最大值的位置
daochu();
if(!daoru())
{
System.out.print("数据导入失败");
return;
}
else System.out.print("数据导入成功"); //int num=0;
//手动输入区域
//--------------------------------------------
// System.out.println("请输入你想要查找数组的长度:");
// while(num<=0) //实现用户输入数组的大小
// {
// if(it.hasNextInt())
// {
// num=it.nextInt();
// if(num<=0)
// {
// System.out.println("输入数组不能小于等于0,请重新输入");
// }
//
// }
// else
// {
// it.next();
// System.out.println("输入格式错误,请重新输入");
// }
// }
//-------------------------------------------- max.add(new BigInteger("0")); //添加一个max使其为0
for(int i=1;i<=nums.size();i++) //储存数组
{
//--------------------------------------------
//手动输入区域
//System.out.println("请输入第"+i+"个数:");
BigInteger g_down=null; // while(g_down==null)
// {
// if(it.hasNextInt())
// {
g_down=nums.get(i-1); max.add(g_down.add(max.get(i-1)));
//nums.add(g_down); // }
// else
// {
// it.next();
// System.out.println("输入格式错误,请重新输入");
// }
// }
//-------------------------------------------- } System.out.println("输入的数组是"+nums.toString()); BigInteger minn=max.get(0);
int minp=0;
BigInteger remax=max.get(1);
maxp=0;
for(int i=1;i<max.size();i++)
{
List<BigInteger> max2=max.subList(0, i);
BigInteger g_min=min(max2);
if(max.get(i).subtract(g_min).compareTo(remax)==1)
{
remax=max.get(i).subtract(g_min);
maxp=i-1;
minp=max.indexOf(g_min);
}
} System.out.println("最大子数组和为是"+(remax.subtract(minn))+",位置为("+(minp+1)+","+(maxp+1)+")"); //it.close();
}
public static void daochu() throws IOException
{
File a=new File("suzu.txt");
FileOutputStream b = new FileOutputStream(a);
OutputStreamWriter c=new OutputStreamWriter(b,"UTF-8");
for(int i=0;i<10000;i++)
{
int g_down=(int) (Math.random()*2000000000);
if((int) (Math.random()*2)==0)
{
g_down=-g_down;
}
if(i==0)
c.append(g_down+"");
else c.append(" "+g_down); }
c.close();
b.close();
}
public static BigInteger min(List<BigInteger> max)
{
BigInteger g_min=max.get(0);
for(BigInteger it:max)
{
if(g_min.compareTo(it)==1)
{
g_min=it;
}
}
return g_min;
}
public static String change(String i)
{
if(i==null||i.equals(""))
return null;
else if(i.contains("-"))
return i.replace("-", "");
else return "-"+i;
}
//----导入测试
@SuppressWarnings("resource")
public static boolean daoru() throws IOException
{ File a=new File("suzu.txt");
if(!judeFileExists(a))
{
System.out.println("文件不存在");
return false;
}
FileInputStream b = new FileInputStream(a);
InputStreamReader c=new InputStreamReader(b,"UTF-8");
{
BufferedReader bufr =new BufferedReader(c);
String line = null;
while((line = bufr.readLine())!=null){
String ook[]=line.split(" ");
for(String it:ook)
{
if(!isNumeric(it))
{
System.out.println("出现错误类型的数组,不能继续执行程序");
return false;
}
else
{
nums.add(new BigInteger(it));
}
} }
bufr.close();
}
c.close();
b.close();
return true;
}
//文件判断是否存在
public static boolean judeFileExists(File file) { if (file.exists()) {
return true;
} else {
return false;
} }
//判断纯数字
public static boolean isNumeric(String str) {
Pattern pattern = Pattern.compile("-?[0-9]*");
if(str==null||str.equals(""))
return false;
Matcher isNum = pattern.matcher(str);
if (!isNum.matches()) {
return false;
}
return true;
} }
接下来是对文件中9w个数的数组进行求最大子集和的结果:(16GB RAM,Window10 64位系统,i7 7700Hq下耗时半分钟之内)
这是文件里面的数据
测试其健壮性,在文件中9w条数据的任意位置插入任意错误的数据试试:
输出结果如下,能考虑到的健壮性没问题(没有文件的测试下也没有问题):
Java实验——输出一个数组里面连续子数组最大的和(二)文件操作的更多相关文章
- Task 4 求数组的连续子数组的最大和(团队合作)
小组成员:李敏.刘子晗 1.设计思想:由于已经做过这个题目,只要对之前的程序加上相应的测试和约束即可.我们两个人一起商议后,决定了程序的主框架和并列出了最终可以实现的功能.先要定义数组长度和上下限的变 ...
- lintcode循环数组之连续子数组求和
v 题目:连续子数组求和 II 给定一个整数循环数组(头尾相接),请找出一个连续的子数组,使得该子数组的和最大.输出答案时,请分别返回第一个数字和最后一个数字的值.如果多个答案,请返回其中任意一个. ...
- Java实现 LeetCode 581 最短无序连续子数组(从两遍搜索找两个指针)
581. 最短无序连续子数组 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: ...
- 【Java】 剑指offer(42) 连续子数组的最大和
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个整型数组,数组里有正数也有负数.数组中一个或连续的多个整/ ...
- 【Java】 剑指offer(44) 连续子数组的最大和
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 数字以0123456789101112131415…的格式序列化到 ...
- Dp解决数组中连续子数组的最大和
#include<iostream> ]; ;i<size;i++) { TempSum = CurSum; ) ...
- 求数组的相邻子数组的最大值(txt文件存储)
package mypackage; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File ...
- lintcode :continuous subarray sum 连续子数组之和
题目 连续子数组求和 给定一个整数数组,请找出一个连续子数组,使得该子数组的和最大.输出答案时,请分别返回第一个数字和最后一个数字的值.(如果两个相同的答案,请返回其中任意一个) 样例 给定 [-3, ...
- 最大连续子数组问题2-homework-02
1) 一维数组最大连续子数组 如第homework-01就是一维数组的最大子数组,而当其首位相接时,只需多考虑子数组穿过相接的那个数就行了! 2)二维数组 算法应该和第一次的相似,或者说是将二维转化为 ...
随机推荐
- 洛谷 U10223 Cx大帝远征埃及
题目背景 众所周知,Cx是一个宇宙大犇.Cx能文善武,一直在为大一统的实现而努力奋斗着.Cx将调用他的精锐军队,一个精锐士兵最多可以战胜十个埃及士兵.同时Cx是个爱才的人,他想要制定一份能使在占领埃及 ...
- 【C++】cerr,cout,clog
http://stackoverflow.com/questions/16772842/what-is-the-difference-between-cout-cerr-clog-of-iostrea ...
- vue render {} 对象 说明文档
Vue学习笔记进阶篇——Render函数 http://www.mamicode.com/info-detail-1906336.html 深入data object参数 有一件事要注意:正如在模板语 ...
- es6 fs 输出文件 iviewDemo
// fs.open('./env.js', 'w', function(err, fd) { // // const buf = 'export default "development& ...
- 一篇文章搞懂高级程序员、架构师、技术总监、CTO从薪资到技能的区别
一篇文章搞懂高级程序员.架构师.技术总监.CTO从薪资到技能的区别 http://youzhixueyuan.com/senior-programmers-architects-technical-d ...
- 【搜索】P1219 八皇后
题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...
- 【php】查看扩展的版本
php --ri [扩展名称] 例如: php --ri mongodb mongodb MongoDB support => enabled MongoDB extension version ...
- JS 手机号中间4位变星号
一:正则方法 var str1 = '13991367972'var reg = /^(\d{3})\d*(\d{4})$/;var str2 = str1.replace(reg,'$1****$2 ...
- Yii1 获取当前请求的url
echo Yii::app()->getRequest()->getUrl();
- 洛谷 P2858 奶牛零食
https://www.luogu.org/problemnew/show/P2858 毫无疑问区间dp. ![区间dp入门] 我们定义dp[i][j]表示从i到j的最大收益,显然我们需要利用比较小的 ...