public class ScoreCard { strong text
private double[] scores;
/**
* @param val
* @param low
* @param high
* @return low if val < low,
* high if val > high,
* val if val is between low and high
*/
private double constrain(double val, int low, int high) {
if (val < low)
return low;
if (val > high)
return high;
else
return val;
}
/**
* DEEP copy m into scores with each item contrained between 0 and 100.
* use method {@link this#constrain(double, int, int)}.
* For example, if s = {-15.2, 67.4, 126.8}, scores should become
* {0, 67.4, 100}, AND scores should be a DEEP copy of s.
* @param s (assume s is not null)
*/
public void setMarks(double[] s) {
for(int i = 0; i < s.length; i++) {
if (s[i] < 0 || s[i] > 100)
constrain(s[i], 0, 100);
this.scores[i] = s[i];
}
}
私はこのコードの部分にしばらくお待ちしています。 Javadocの状態として、私は<が0になり、得点が> 100〜100になるように "setMarks"に "constrain"のパラメータを呼び出すのに問題があります。自分のコードがディープコピーを正しく作成しているとは思わない「s」を「スコア」に正しく変換します。メソッドにパラメータを渡してディープコピーを作成する
正しい方向へのプッシュは非常に高く評価されます。
。 –