Что не так с этим решением? (Тест на совместимость Пермь-Миссинг-Элем)Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Что не так с этим решением? (Тест на совместимость Пермь-Миссинг-Элем)

Сообщение Anonymous »

Я начал играться с кодильностью и столкнулся с такой проблемой:


Дан массив A с нулевым индексом, состоящий из N различных целых чисел .
Массив содержит целые числа в диапазоне [1..(N + 1)], что означает
, что отсутствует ровно один элемент.

Ваша цель — найти недостающий элемент.

Напишите функцию:

Код: Выделить всё

int solution(int A[], int N);
что для массива A с нулевым индексом возвращает значение отсутствующего элемента
.

Например, задан массив 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);
}
который дал мне оценку 66 из 100, поскольку не прошел тест с использованием больших массивов:
"последовательность диапазона большого_диапазона, длина = ~100 000" с результатом:
ОШИБКА ВЫПОЛНЕНИЯ
тестируемая программа неожиданно завершилась
stdout:
Неверный тип результата, ожидается int.

Я тестировал локально с массивом из 100 000 элементов, и все работало без проблем. Итак, в чем проблема с моим кодом и какие тестовые примеры использовала Codility для возврата «Неверный тип результата, ожидается int»?

Подробнее здесь: https://stackoverflow.com/questions/197 ... ility-test
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»