Я хотел бы написать программу, которая складывает все числа в массив целых чисел - за исключением! Поскольку число 6 не самое хорошее, я предлагаю исключить все разделы чисел, начиная с 6 и заканчивая 7 - включительно. Каждые 6 всегда будут сопровождаться 7 , но не обязательно наоборот.
Вот несколько примеров входных массивов и их ожидаемого вывода:
sum67([1, 2, 2, 6, 99, 99, 7]) = 5
Все цифры от 6 до 7 исключены.
sum67([1, 2, 2]) = 5
Нет 6 или 7 здесь.
sum67([1, 1, 6, 7, 2]) → 4
Ни 6, ни 7 не включены.
Все вышеуказанные тесты пройдены.
Еще раз, заголовок метода исправлен, и я могу только изменить тело метода. Вот моя попытка кода:
public int sum67(int[] nums) {
int sum = 0;
for (int i = 0; i < nums.length; i++) {
// Adding all numbers that are not a 6
if (nums[i] != 6) sum += nums[i];
}
for (int j = 0; j < nums.length; j++) {
// check for the sixes - the lower bound exclusive
if (nums[j] == 6) {
for (int k = j + 1; k < nums.length; k++) {
// check for the sevens - the upper bound inclusive
if (nums[k] == 7) {
// take away all the numbers between the 2 bounds, including the 7
for (int m = j + 1; m <= k; m++) {
sum -= nums[m];
}
}
}
}
}
return sum;
}
Вышеуказанная программа не только не работает , но и явно крайне грязная. В частности, он не проходит следующие тесты, среди прочего:
sum67([1, 6, 2, 6, 2, 7, 1, 6, 99, 99, 7]) = 2
Фактический вывод -463
!
sum67([2, 2, 6, 7, 7]) = 11
Фактический вывод - -3
.
Итак, по сути:
Где строка ошибки или строки в моем коде?
Есть ли лучший способ написания этой программы, который не имеет столько циклов и вложенных if
с?