最大子序列问题:给定一整数序列A1,A2,A3...An(可能有负数),求A1~An的一个最大子序列Ai~Aj的和。
2015-03-31 18:09
671 查看
这是一道PPTV2015年校园招聘笔试题目。
例:一次程序运行结果
请输入序列长度n:
6
请输入n个序列值:
-1 3 -2 4 5 -6
the substring is:
START...2
END.....5
MaxSum is 10.0
/*
* 问题:
* 最大子序列问题:给定一整数序列A1,A2,A3...An(可能有负数),求A1~An的一个最大子序列Ai~Aj的和。
*
*/
import java.util.Scanner;
public class pptv_bishi {
//双重循环法求解,时间复杂度O(n*3)。
public static void main(String[] args) {
// TODO Auto-generated method stub
int n;
System.out.println("请输入序列长度n:");
Scanner in=new Scanner(System.in);
n=in.nextInt();
System.out.println("请输入n个序列值:");
int [] arr=new int[n+1];
for(int i=1;i<=n;i++){//输入序列An。
arr[i]=in.nextInt();
}
in.close();
double sum=0;//记录最大子序列和。
double temp=0;
int low=0,high=0;
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j++){
temp=doSearch(i,j,arr);
if(temp>sum){
sum=temp;
low=i;
high=j;
}
}
}
System.out.println("the substring is: \nSTART..."+low+"\nEND....."+high+"\nMaxSum is "+sum);
}
private static double doSearch(int low,int high,int[] arr) {
// TODO Auto-generated method stub
double value=0;
for(int i=low;i<=high;i++){
value+=arr[i];
}
return value;
}
}
例:一次程序运行结果
请输入序列长度n:
6
请输入n个序列值:
-1 3 -2 4 5 -6
the substring is:
START...2
END.....5
MaxSum is 10.0
/*
* 问题:
* 最大子序列问题:给定一整数序列A1,A2,A3...An(可能有负数),求A1~An的一个最大子序列Ai~Aj的和。
*
*/
import java.util.Scanner;
public class pptv_bishi {
//双重循环法求解,时间复杂度O(n*3)。
public static void main(String[] args) {
// TODO Auto-generated method stub
int n;
System.out.println("请输入序列长度n:");
Scanner in=new Scanner(System.in);
n=in.nextInt();
System.out.println("请输入n个序列值:");
int [] arr=new int[n+1];
for(int i=1;i<=n;i++){//输入序列An。
arr[i]=in.nextInt();
}
in.close();
double sum=0;//记录最大子序列和。
double temp=0;
int low=0,high=0;
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j++){
temp=doSearch(i,j,arr);
if(temp>sum){
sum=temp;
low=i;
high=j;
}
}
}
System.out.println("the substring is: \nSTART..."+low+"\nEND....."+high+"\nMaxSum is "+sum);
}
private static double doSearch(int low,int high,int[] arr) {
// TODO Auto-generated method stub
double value=0;
for(int i=low;i<=high;i++){
value+=arr[i];
}
return value;
}
}
相关文章推荐
- 一道题:给定一整数序列A1,A2,...,An(可能有负数),求A1到An的一个自序列,使得Ai到Aj的和最大。例如:整数序列-2,11,-4,13,-5,2,-5,-3,12,-9的最大子序列为21
- 数据结构与算法——给定整数A1,A2,....An,....(可能有负数),求该数据序列的最大子序列的和
- 给定一个数列a1,a2,a3,...,an和m个三元组表示的查询,对于每个查询(i,j,k),输出ai,ai+1,...,aj的升序排列中第k个数。
- 给定一个数列a1,a2,a3,...,an和m个三元组表示的查询,对于每个查询(i,j,k),输出ai,ai+1,...,aj的升序排列中第k个数。
- 给定一个递增序列,a1 <a2 <...<an 。定义这个序列的最大间隔为d=max{ai+1 - ai }(1≤i<n),现在要从a2 ,a3 ..an-1 中删除一个元素。问剩余序列的最大间隔最小是多少?
- zoj 3512 Financial Fraud 给定一个整数序列a1, a2, … , an,求一个不下降序列b1 ≤ b2 ≤ … ≤ bn,使得数列{ai}和{bi}的各项之差的绝对值之和 |
- 给一个数组[a1,a2,a3....an],要求出令ai-aj有最大值,其中i<=j,时间和空间复杂度尽可能小
- 求浮点数数组A={A1,A2,A3,…,An}中,Aj-Ai(j>i)的最大值。要求时间复杂度越小越好
- 给定整数a1、a2、a3、...、an,判断是否可以从中选出若干个数,使得它们的和等于k(k任意给定,且满足-10^8 <= k <= 10^8)。
- 给定整数a1、a2、a3、...、an,判断是否可以从中选出若干个数,使得它们的和等于k(k任意给定,且满足-10^8 <= k <= 10^8)。
- 面试-链表逆置 作业手写一个单链表,并且实现单链表元素的逆置,(a0, a1,a2,a3,..an)-> (an,an-1,… a1, a0),算法的空间复杂度和时间复杂度经可能低
- [原创]关于a1,a2,a3,...,an共n个元素依次入栈其可能出栈的排列数的计算
- (学习日记)关于a1,a2,a3,...,an共n个元素依次入栈其可能出栈的排列数的计算(catalan数)
- 【codeforces 727 C】【交互题 求原数组】【告诉你有一个长度为n序列,你可以问n个问题,每个问题为ai+aj等于多少,最后输出这个序列】
- 程序员面试金典——解题总结: 9.17中等难题 17.8给定一个整数数组(有正数有负数),找出总和最大的连续数列,并返回总和
- 有一个带头结点的单链表L={a1,b1,a2,b2,...,an,bn},设计一个算法将其拆分成两个带头结点的单链表A和B,正序链表A={a1,a2,a3...,an},逆序链表B={bn,bn-1,
- 给一个数组,元素都是整数(有正数也有负数),寻找连续的元素相加之和为最大的序列。
- 给定一个整数(字符串也适用)序列,重新排列,得到最大的结果,比如31,3,35,7,9根据排列后得到组合 9735331,返回的是string类型
- 输入a1,a2,...,an,b1,b2,...,bn, 将这个序列顺序改为a1,b1,a2,b2,a3,b3,...,an,bn
- 给定一个整数数组(有正数有负数),找出总和最大的连续数列,并返回总和。