C (Си) : Массивы

Тема массивов в С довольно обширна. В этом уроке мы познакомимся с базовыми концепциями работы с массивами.

Задание

Допишите функцию int sum(int *arr, length), которая принимает массив и его размер и возвращает сумму элементов массива.

Упражнение не проходит проверку — что делать? 😶

Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:

  • Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.
В моей среде код работает, а здесь нет 🤨

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Мой код отличается от решения учителя 🤔

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.

В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Прочитал урок — ничего не понятно 🙄

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.

Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются
Loading...

Ваше упражнение проверяется по этим тестам

1#include "greatest.h"
2#include "main.c"
3
4TEST test_base(void) {
5    int arr_positive[5] = { 1, 2, 3, 4, 5 };
6    int arr_negative[5] = { -2, -3, -4, -5, 8 };
7    int arr_empty[] = {};
8
9    ASSERT_EQ(15, sum(arr_positive, 5));
10    ASSERT_EQ(-6, sum(arr_negative, 5));
11    ASSERT_EQ(0, sum(arr_empty, 0));
12    PASS();
13}
14
15GREATEST_MAIN_DEFS();
16
17int main(int argc, char **argv) {
18    GREATEST_MAIN_BEGIN();
19    RUN_TEST(test_base);
20    GREATEST_MAIN_END();
21}
22

Решение учителя откроется через:

20:00
waiting_clock
← Предыдущий