【发布时间】:2018-06-08 03:00:13
【问题描述】:
这个程序基本上检查给定整数序列的两端,将两者中的最大值加到 R 中,并更改我们没有选择的一端的符号。重复该过程,直到只剩下一个数字(不添加到 R)。输入的第一行指定了序列中整数的数量,剩下的就是序列本身。
例如,如果我们输入“5 5 4 3 2 1”,我们应该得到“14”,因为只有“1”不会被添加到 R。
由于某种原因,当我输入“5 -5 -4 -3 -2 -1”时,我得到的输出是“10”而不是“-10”。
#include <iostream>
using namespace std;
int main(void) {
int N, *L, R = 0, i = 0, d = 0;
cin >> N;
L = new int[N];
for (; i < N; ++i) cin >> L[i];
i = 0;
d = N - 1;
while (d != i) {
if (L[i] > L[d]){
R += L[i];
L[d] *= -1;
++i;
}
else {
R += L[d];
L[i] *= -1;
--d;
}
}
cout << R << endl;
return 0;
}`
【问题讨论】:
-
用调试器单步调试程序,我希望你会看到。
-
L[d] *= -1;将负数变为正数。 -
这看起来像是“如何调试小程序”的工作......
-
是的,但是 L[d] *= -1 只会改变我们没有添加的整数。
标签: c++ integer add negative-integer