我有这个执行,这个程序的结果是100,但正确答案是103 是任何人都知道什么是错在这个实现或是否有更好的办法用于查找数组中整数的最大连续和?找到整数的最大连续总和在阵列
在此先感谢。
#include <stdio.h>
int main(void) {
int a[] = { -3, 100, -4, -2, 9, -63, -200, 55 };
int max_sum, temp_sum, i, n = 12, t;
temp_sum = max_sum = a[0];
for (i = 1; i < n; i++) {
if (a[i] > 0)
temp_sum += a[i];
else {
t = 0;
while (a[i] < 0 && i < n) {
t += a[i];
i++;
}
if (temp_sum + t > 0) {
temp_sum = temp_sum + t + a[i];
if (temp_sum > max_sum)
max_sum = temp_sum;
} else if (i < n)
temp_sum = a[i];
}
}
if (temp_sum > max_sum)
max_sum = temp_sum;
printf("Maximum Numbers is %d \n", max_sum);
return 0;
}
这里有smt怪异的,我把你的代码复制到CodeBlocks,结果是332? – 2012-04-10 19:48:45
这是功课吗?你应该考虑使用递归。 – 2012-04-10 19:49:59
“最大连续数”是什么意思?你怎么能得到103? – Saphrosit 2012-04-10 19:50:20