java高手帮一下忙,怎么程序就有问题呢?

packagesuanfafenxi3;publicclassfirst{publicvoidmaxSubarray(int[]array,int[]tailarray,... package suanfafenxi3;

public class first {
public void maxSubarray(int[] array,int[] tailarray,int max)
{ int i,j,k,n=array.length;
for(i=1,tailarray[0]=1;i<n;i++)
{for(j=0,k=0;j<i;j++)
{
if(array[j]<=array[i]&&k<tailarray[j]) k=tailarray[j];
tailarray[i]=k+1;
}
}
int temp;
for(i=0,temp=0;i<n;i++)
{
if(tailarray[i]>temp) temp=tailarray[i];

}
max=temp;
}
public static void main(String[] args) {
int[] array={1,4,7,20,2,11,5,13,6,10};
int[] tailarray={0};
int max=0;
first a=new first();
a.maxSubarray(array, tailarray, max);
System.out.print(max);
}

}
展开
 我来答
lengon
2010-11-01 · TA获得超过2125个赞
知道小有建树答主
回答量:1769
采纳率:0%
帮助的人:1027万
展开全部
因为int[] tailarray={0};定义了你的tailarray的length只有1。导致你
tailarray[i]=k+1;里面的i会超过1,具体的可以改为
int[] tailarray = new int[10];
tailarray[0] = 0;
int max = 0;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式