java-四则运算-四
题目要求:查找数组连成环形的和最大的连续子数组
实验代码:
package zuoYe;
import java.util.Scanner;
public class MaxSubArray {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
//输入数据
System.out.println("请输入数组长度");
int n = scan.nextInt();
int[] a = new int[n];
System.out.println("请输入数组元素");
for(int i = 0;i < n;i++)
{
a[i] = scan.nextInt();
}
scan.close();
//计算此数组的和最大的连续子数组
int[] result = maxSub(a,a.length);
System.out.println("不连接成环的和最大的连续子数组:");
for(int i = result[0];i <= result[1];i++)
{
System.out.print(a[i] + "\t");
}
System.out.println("和为:" + result[2]);
//将此数组连成一个环,再计算此数组的和最大的连续子数组
//连成一个环即将数组后再接上此数组,但是数组的最后一个元素不用接,相当于计算接上之后的数组的和最大子数组
int[] b = new int[2 * n - 1];
for(int i = 0;i < n - 1;i++)
{
b[i] = a[i];
b[n + i] = a[i];
}
b[n - 1] = a[n - 1];
int[] result2 = maxSub(b,n);
System.out.println("\n\n将数组连成环后的和最大的连续子数组:");
for(int i = result2[0];i <= result2[1];i++)
{
System.out.print(b[i] + "\t");
}
System.out.println("和为:" + result2[2]);
}
//计算a数组的和最大的连续子数组(a数组为连成环后的等价数组,即原数组的二倍,n为原数组的长度)
public static int[] maxSub(int[] a,int n)
{
int an = a.length;//连成环的等价数组的长度
int currectSum = a[0];//记录当前累加和,初始值为a[0]
int currectStartIndex = 0;//记录当前累加的起始下标,初始值为0
int count = 1;//记录累加元素的个数,初始值为1
int[] result = new int[3];//记录结果子数组的信息,
result[0] = 0;//结果子数组的开始下标
result[1] = 0;//结果子数组的结束下标
result[2] = a[0];//结果子数组的和
for(int i = 1;i < an;i++)//依次遍历a数组的每个元素
{
if(currectSum <= 0)//如果当前累加和不大于0,不大于0对后续的元素没有贡献,可以去掉了,所以应从a[i]处重新开始加
{
currectSum = a[i];//将当前累加和赋值为a[i]
currectStartIndex = i;//将当前累加的开始下标赋值为i
count = 1;//将累加元素的个数记为1
}
else//当前累加和大于0,则继续加a[i]
{
currectSum += a[i];
count++;//当前累加元素的个数加一
}
if(currectSum > result[2])//如果当前累加和大于原结果数组的累加和result[2],则应该将结果子数组信息更新为当前子数组,因为当前子数组的累加和大于结果子数组的和
{
result[0] = currectStartIndex;//结果子数组的开始下标为当前子数组的开始下标
result[1] = i;//结果子数组的结束下标赋值为i
result[2] = currectSum;//结果子数组的累加和赋值为当前子数组的累加和
}
if(count >= n)//如果累加的元素个数等于原数组(未连成环的数组)的长度,则说明已经加了最多的元素,不能再加了,也就是说和最大的子数组即为原数组,应该结束循环
{
break;
}
}
return result;
}
}
实验截图:

java-四则运算-四的更多相关文章
- Java的四种内部类
Java的四种内部类包括如下: 成员内部类 静态内部类 局部内部类 匿名内部类 成员内部类: 定义在另一个类(外部类)的内部,而且与成员方法和属性平级叫成员内部类,......相当于外部类的非静态方法 ...
- Java实验四
20145113 Java实验四 快捷键 之前没怎么记ISDEA的快捷键,但是熟练使用快捷键可以带来很多的便利,于是先开始学习一些常用的快捷键,就采用它默认的快捷键,这样后期就不会出现冲突,一些and ...
- Java中四种引用:强、软、弱、虚引用
这篇文章非常棒:http://alinazh.blog.51cto.com/5459270/1276173 Java中四种引用:强.软.弱.虚引用 1.1.强引用当我们使用new 这个关键字创建对象时 ...
- java中四种引用类型
java中四种引用类型 今天看代码,里面有一个类java.lang.ref.SoftReference把小弟弄神了,试想一下,接触java已经有3年了哇,连lang包下面的类都不了解,怎么混.后来在 ...
- 《Thinking In Java第四版》拾遗
<Thinking In Java第四版>拾遗 转自我的github(http://katsurakkkk.github.io/2016/05/Thinking-In-Java%E7%AC ...
- Java第四次上课博文动手动脑
Java第四次上课博文动手动脑 1. 查看String.equals()方法 public class StringEquals { /** * @param args the command ...
- Java进阶(四十七)Socket通信
Java进阶(四十七)Socket通信 今天讲解一个 Hello Word 级别的 Java Socket 通信的例子.具体通讯过程如下: 先启动Server端,进入一个死循环以便一直监听某端口是 ...
- Java进阶(四十三)线程与进程的区别
Java进阶(四十三)线程与进程的区别 1.线程的基本概念 概念:线程是进程中执行运算的最小单位,是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点在运行中必 ...
- Java进阶(四十二)Java中多线程使用匿名内部类的方式进行创建3种方式
Java中多线程使用匿名内部类的方式进行创建3种方式 package cn.edu.ujn.demo; // 匿名内部类的格式: public class ThreadDemo { public st ...
- Java进阶(四十)Java类、变量、方法修饰符讲解
Java进阶(四十)Java类.变量.方法修饰符讲解 Java类修饰符 abstract: 将一个类声明为抽象类,没有实现的方法,需要子类提供方法实现. final: 将一个类生命为最终(即非继承类) ...
随机推荐
- c# WinForm软件启动拦截(通过更改文件关联实现)
前几天想做一个软件启动之前拦截的程序,找了下网上的资料没有找到合适的,突然看到电脑软件某看图软件,找到个思路就是跟他一样的,通过修改文件关联进行启动拦截. 原理是这样的,更改.exe默认的启动方式为我 ...
- 2015-03-11——简析DOM规范
DOM 0级指浏览器专有的,非标准的方法.对象和集合. DOM 1级 1998年发布包括:DOM coreDOM html DOM 2级 DOM2 core 2000年发布 DOM2 html 20 ...
- log4j 日志相关
1.log 打印异常信息 Logger logger = Logger.getLogger(LoggerTest.class); //追踪产生此日志的类 Logger extends Categor ...
- mysql多条更新
最近在完成MySql项目集成的情况下,需要增加批量更新的功能,根据网上的资料整理了一下,很好用,都测试过,可以直接使用. mysql 批量更新共有以下四种办法 1..replace into 批量更新 ...
- What are the top 10 things that we should be informed about in life
1.Realize that nobody cares, and if they do, you shouldn't care that they care. Got a new car? Nobod ...
- WEB安全验收参考文档——From Github
文章https://xianzhi.aliyun.com/forum/read/793.html 里面涉及到了web安全验收参考文档: 其实github上老外对此也做过一些整理.详情参考:https: ...
- java 中JFinal getModel方法和数据库使用出现问题解决办法
JFinal getModel方法(从页面表单中获取Model对象)+数据库存储问题 一.getmodel方法 1.在JConfig配置类中的数据库映射(存储到数据库时需要此配置) public vo ...
- JavaScript历史和标准
不管新手老手, 学门语言如果不简单了解这门语言谁创立的, 什么时候, 现在由谁来维护, 规范在哪? 总感觉, 少了点什么, 我就是这样. 历史 1994年美国网景(Netscape)公司发布自己的浏览 ...
- windows10下安装face_recongnition
第一步:安装vistual studio,我安装的是最新版本2017. 另外,并且因为要学习C# ,选了所需要的东西.暂不知这一步是否必需. 第二步:接下来安装boost 通过此链接:https:// ...
- oradebug工具使用3(转载)
1 oradebug介绍 oradebug主要是给oracle支持人员使用的,尽管很早便有,但oracle官网很少有记载.他是个sql*plus命令行工具,有sysdba的权限就可以登入,无需特别设置 ...