编写一个程序,将一个整数序列读入数组,并计算数组中所有元素的交替和。例如,如果使用输入数据执行程序
1 4 9 16 9 7 4 9 11然后计算
1-4+9- 16 +9-7+4-9+ 11 =-2
到目前为止,我有以下代码:
import java.util.Arrays;
/**
This class computes the alternating sum
of a set of data values.
*/
public class DataSet
{
private double[] data;
private int dataSize;
/**
Constructs an empty data set.
*/
public DataSet()
{
final int DATA_LENGTH = 100;
data = new double[DATA_LENGTH];
dataSize = 0;
}
/**
Adds a data value to the data set.
@param x a data value
*/
public void add(double x)
{
if (dataSize == data.length)
data = Arrays.copyOf(data, 2 * data.length);
data[dataSize] = x;
dataSize++;
}
/**
Gets the alternating sum of the added data.
@return sum the sum of the alternating data or 0 if no data has been added
*/
public double alternatingSum()
{
. . .
}
}我必须使用下面的类作为测试类:
/**
This program calculates an alternating sum.
*/
public class AlternatingSumTester
{
public static void main(String[] args)
{
DataSet data = new DataSet();
data.add(1);
data.add(4);
data.add(9);
data.add(16);
data.add(9);
data.add(7);
data.add(4);
data.add(9);
data.add(11);
double sum = data.alternatingSum();
System.out.println("Alternating Sum: " + sum);
System.out.println("Expected: -2.0");
}
} 发布于 2012-04-07 17:45:06
我为您实现了alternatingSum方法:
public double alternatingSum() {
double alternatingSum = 0;
if(data != null || dataSize > 0) {
for(int i = 0; i < dataSize; i = i + 2) {
alternatingSum += data[i];
}
for(int i = 1; i < dataSize; i = i + 2) {
alternatingSum -= data[i];
}
}
return alternatingSum;
}发布于 2012-04-07 15:21:28
我会使用这个简单的逻辑来实现目标。首先将数组中的所有奇数相加。然后将相同的所有偶数相加。现在减去这两个值n,你会得到你的答案。希望这能有所帮助。
发布于 2012-04-07 15:27:15
我会使用一个for循环和一个布尔标志来解决这个问题:
set flag to false
set sum to zero
for alle elements in array
if flag is set
add to sum
else
subtract from sum
When loop is done you have your sum.https://stackoverflow.com/questions/10052568
复制相似问题