Skip to content

Домашнее задание 3.3. Количество нулевых элементов в массиве. Разгуляева А.И. #16

Open
ada1ra wants to merge 1 commit intomainfrom
hw_3-3_arrayCountZeros
Open

Домашнее задание 3.3. Количество нулевых элементов в массиве. Разгуляева А.И. #16
ada1ra wants to merge 1 commit intomainfrom
hw_3-3_arrayCountZeros

Conversation

@ada1ra
Copy link
Owner

@ada1ra ada1ra commented Dec 16, 2025

Добавила решение домашнего задания 3.3. Количество нулевых элементов в массиве.

Разгуляева А.И. 25.Б42-мм

Comment on lines +10 to +19
printf("Введите числа для добавления в массив или строку для конца ввода:\n");
while (scanf("%d", &arr[countLen]) == 1)
countLen += 1;

// подсчет нулевых элементов
for (int i = 0; i < countLen; i++) {
if (arr[i] == 0) {
count++;
}
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

При такой организации решения можно было сделать ещё эффективнее и вообще без дополнительной памяти (только две интовые переменные). И решение получится строчек в 7.
Если сообразите, как это сделать, будет дополнительный балл.

Copy link
Owner Author

@ada1ra ada1ra Dec 16, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Считать сразу при вводе, чтобы убрать дополнительный цикл? Даже если убрать вывод массива и вставить проверку на нулевые элементы внутри цикла с вводом массива, уберутся две int i = 0, но всё равно останется 3 переменных (int arr, int count, int countLen для индексации), или Вы не считаете массив за переменную? Или я не поняла способ?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

А зачем хранить массив (если убрать вывод массива в конце)?

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

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

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Да, в чем-то Вы правы.

Но, я думаю, здесь есть два варианта:

  • по-честному проверять количество ненулевых элементов в массиве отдельной функцией
  • проверять количество элементов среди введённых с клавиатуры чисел

В задании не было сказано, какой вариант нужно реализовать, поэтому можно было сделать как угодно.

Почему в первом варианте предпочтительна отдельная функция, думаю, объяснять не нужно. При этом, у Вас её нет.

Поэтому я Вам предлагаю на дополнительный балл сделать максимально эффективную реализацию второго варианта. Можете сделать отдельной веткой, если считаете, что это будет некорректное решение задачи.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#18

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants