Дан массив A с нулевым индексом, состоящий из N различных целых чисел .
Массив содержит целые числа в диапазоне [1..(N + 1)], что означает
, что отсутствует ровно один элемент.
Ваша цель — найти недостающий элемент.
Напишите функцию:
Код: Выделить всё
int solution(int A[], int N);
.
Например, задан массив A такой, что:
A[0] = 2 A[1] = 3 A[2] = 1 A[3] = 5
функция должна возвращать 4, так как это недостающий элемент.
Предположим, что:
Код: Выделить всё
N is an integer within the range [0..100,000];
the elements of A are all distinct;
each element of array A is an integer within the range [1..(N + 1)].
Код: Выделить всё
expected worst-case time complexity is O(N);
expected worst-case space complexity is O(1), beyond input storage (not counting the storage required for input arguments).
Я представил следующее решение (на PHP):
Код: Выделить всё
function solution($A) {
$nr = count($A);
$totalSum = (($nr+1)*($nr+2))/2;
$arrSum = array_sum($A);
return ($totalSum-$arrSum);
}
"последовательность диапазона большого_диапазона, длина = ~100 000" с результатом:
ОШИБКА ВЫПОЛНЕНИЯ
тестируемая программа неожиданно завершилась
stdout:
Неверный тип результата, ожидается int.
Я тестировал локально с массивом из 100 000 элементов, и все работало без проблем. Итак, в чем проблема с моим кодом и какие тестовые примеры использовала Codility для возврата «Неверный тип результата, ожидается int»?
Подробнее здесь: https://stackoverflow.com/questions/197 ... ility-test
Мобильная версия