从我上一篇随笔中,我们可以得到最大连续子数组。

  按照要求,我们需要从TXT文档中读取随机数,那在此之前,我们需要在程序中写入随机数

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Random; public class Main {
public static void main(String[] args) {
File f = new File("C:/D/shuzu.txt"); if(!f.exists())
try {
f.createNewFile(); } catch (IOException e1) {
// TODO 自动生成的 catch 块
e1.printStackTrace();
}
try {
PrintWriter pw = new PrintWriter(f);
for(double i=0;i<90000;i++) {
Random r=new Random();
int i1=r.nextInt(1000);//设置的是0-1000的随机数,然后是每3个写入一个负数
if(i%3==0) {
i1=0-i1;
}
pw.print(i1);
pw.print(",");
if(i==80000) {
System.out.println("到这里了");
}
}
pw.close();
} catch (FileNotFoundException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
}

  这段代码的作用是在TXT文件中输入90000个-1000到1000的随机数,并且以英文的逗号作为分割。

  接下来我们需要进行的操作就是对这个90000个数值进行读取,我采取的方法是使用方法读取之后进读取到的以逗号作为分隔标志,将其储存到String数组中,然后开始对String数组中的每一个进行辨别,判断数组中的每一个元素时候为正数或者为负数,如果是负数则进行排除在计算之外,如果是的话就开始进行大数据字符串的运算,然后再依据上一篇博客的方法对连续的最大子数组进行判断即可。

  估计大家会问到,为什么是输出的是90000个随机数,而不是更大的数值,在第一个程序运行的时候,我发现当我的随机数生成的个数到1000000的时候,程序的运算量就开始变得相当的长,更重要的是在到了这个数量级的时候,即使程序能够显示出已经生成了900000个随机数,但是我的TXT文档却一直无法打开,老师分析的可能是写入的缓存区不够用了导致的,具体的原因我会在之后的时间里找一下问题所在。

  更新:最后证明是能够打开的,时间太长了,我的笔记本是i5 8250U,因为是低压U的关系,所以处理器的性能比起标压U的会小很多,所以在处理文件上会慢很多,所以就设置在了90000个地方稍微会快一点。

  接下来贴出运行代码:

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.math.BigInteger;
import java.util.regex.Matcher;
import java.util.regex.Pattern; public class Main {
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
BigInteger TempNum=new BigInteger("0");
BigInteger Big0=new BigInteger("0");
BigInteger Max=new BigInteger("0");
String subway_1=subway_1("C:/D/shuzu.txt");
System.out.println(subway_1);
for(int i=0;i<number.length;i++) {
boolean flag=Isnumber(number[i]);
if(flag==true) {
System.out.println("输入为数值!");
BigInteger BigNum=new BigInteger(number[i]);
TempNum=TempNum.add(BigNum);
int is=TempNum.compareTo(Big0);
if(is==-1) {
TempNum=new BigInteger("0");
}else {
int is2=TempNum.compareTo(Max);
if(is2!=-1) {
Max=TempNum;
}
}
System.out.println("读取的"+(i+1)+"个数值:"+BigNum);
System.out.println("最大值:"+Max);
}
else
System.out.println("输入不为数值!");
}
}
private static String[]number; private static String subway_1(String file) throws IOException {
// TODO Auto-generated method stub File f=new File(file);
BufferedReader bf=new BufferedReader(new FileReader(f));
String content="";
content=bf.readLine();
String[] temp = content.split(",");
number=temp;
return null;
}
private static boolean Isnumber(String num) { Pattern pattern = Pattern.compile("-?[0-9]+(.[0-9]+)?");
Matcher isNum = pattern.matcher(num);
if( !isNum.matches() ){
return false;
}
return true;
} }

  其实在这个问题中,分为几个模块就可以解决,1.写入数据,2.读取数据并进行拆分,同时检验数据时候符合规范,3.利用大数据字符串的方法来求较多数据情况下的连续字符串的运算。

Java课程课后作业190315之从文档中读取随机数并得到最大连续子数组的更多相关文章

  1. Java课程课后作业190315之最大连续子数组(二维数组版)

    ,, 在本周的课堂上,老师再一次提高了要求,将一维数组升级成为了二维数组,然后求出块状的连续子数组. 一开始还想着借鉴之前球一维数组的O(n)的算法,后来还是没有找到头绪,舍友讲了自己的办法,但是没有 ...

  2. 从多个XML文档中读取数据用于显示webapi帮助文档

    前言: 你先得知道HelpPageConfig文件,不知道说明你现在不需要这个,所以下文就不用看了,等知道了再看也不急.当然如果你很知道这个,下文也不用看了,因为你会了. 方法一: new XmlDo ...

  3. 输出5个大写英文字母的组合,并写入到txt文档中,随机数法。

    1.问题起源:最近想申请几个英文商标,研究了一下,英文字母在4到7个之间最好,5个字母尤佳,所以先来输出5个字母的组合,可是想像力有限,于是想用排列组合把所有5个可能的字母组合都输出,再从中挑选几个感 ...

  4. java课程课后作业190616之个人学期总结

    在团队开始的那一周,我们做了作品的功能畅想,在讲台上谈论了自己的产品可能会有的功能,比如说课程查找功能,空教室查找功能,霸屏功能,课程留言功能等,当然,随着开发的推进,我也发现了有些功能上实现的困难, ...

  5. JAVA课程课后作业之使用递归完成回文

    一.思路 1.我的想法是利用数组的做法来进行,先是用scanner录入一个String类 2.然后就是将String转化成char数组 3.递归的就是第一个和最后一个对比,然后第一个加一,最后一个减一 ...

  6. JAVA课程课后作业03之作业一

    作业:使用类的静态字段和构造函数,可以跟踪某个类所创建对象的个数.请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象?”. 代码: package TestJava; import java ...

  7. java课程课后作业190425之一维数组最大子数组(界面实现)

    题目要求: 1.在第一个问题过程中,我在以前的代码中好像已经写出了这个功能,想要实现这个功能,我们只需要在我们储存的数组和是负数的时候对中转值进行重新赋值就可以得到新的数值的起始位置,而他的终了位置就 ...

  8. java课程课后作业05之动手动脑

    一.使用Files. walkFileTree()找出指定文件夹下所有大于指定大小(比如1M)的文件 此代码没有使用walkfiletree,两者的差别在于walkfiletree在遍历文件的时候有一 ...

  9. java课程课后作业04之动手动脑

    一.多层的异常捕获-1 先贴出代码: public class CatchWho { public static void main(String[] args) { try { try { thro ...

随机推荐

  1. unix域字节流回射程序

    一.服务端程序 #include <stdio.h> #include <errno.h> #include <stdlib.h> #include <uni ...

  2. [译]Ocelot - Getting Started

    原文 Ocelot专为.NET Core而设计. .NET Core 2.1 安装 首先需要创建一个netstandard2.0项目,然后再通过nuget安装. Install-Package Oce ...

  3. 有趣的若干个AI项目

    一.遗传算法跑贪吃蛇 1.下载processing,下载地址是:https://processing.org/download ,直接解压打开即可. 2.下载SnakeAI源码,下载地址是:https ...

  4. DeepLearning.ai学习笔记(五)序列模型 -- week1 循环序列模型

    一.为什么选择序列模型 序列模型可以用于很多领域,如语音识别,撰写文章等等.总之很多优点... 二.数学符号 为了后面方便说明,先将会用到的数学符号进行介绍. 以下图为例,假如我们需要定位一句话中人名 ...

  5. C++ 变长模板参数

    转载自: http://www.cnblogs.com/liyiwen/archive/2013/04/13/3018608.html C++11 语言核心的改进中,最为关注的有 rvalue ref ...

  6. AGC电路以及AD8347正交解调芯片

    1.AGC电路的工作原理 1.1AGC电路的用途 随着电磁环境的日益恶化, 不同频段电磁信号之间的相互串扰, 以及可能出现的人为干扰, 将会导致接收机输入端口的信号动态范围较大, 一旦出现电路饱和或是 ...

  7. undefined reference to `pthread_create'

    问题描述: ubuntu 16.04  下  C语言开发环境, 已经添加了头文件#include <pthread.h> 以及在Makefile中添加了 -lpthread,但是编译时仍然 ...

  8. Flutter终将逆袭!1.2版本发布,或将统一江湖

    在去年 MWC 大展上发布首个 Beta 版后,Flutter 1.0 正式版于 2018 年 12 月召开的 Flutter Live 2018 上正式发布.今天在巴塞罗那召开的 MWC 发布会上, ...

  9. Linux系统中yum 命令讲解

    (一)yum介绍 Yum(全称为 Yellow dogUpdater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器.基于RPM包管理,能够从指定 ...

  10. 在vue里添加好看的lottie动画 (^_^)

    为什么用lottie ★~★ 1.能让你的程序不那么单调 2.能让一些有审美强迫症的同学好受一点 3.网上有丰富的资源 点我进入lottie资源网站 引入lottie库 (>.<) 在vu ...