Вопрос задан 21.06.2023 в 16:25. Предмет Информатика. Спрашивает Самохвалов Макс.

Люди, помогите найти ошибку пожалуйста! задача (Python): Количество различных элементов — 2 Дан

список. Посчитайте, сколько в нём различных элементов, не изменяя самого списка. Входные данные: Вводится список чисел. Все числа списка находятся на одной строке. Все числа целые неотрицательные и не больше 1000. Выходные данные: Выведите ответ на задачу. Мой вариант решения: e = list(map(int, input().split())) count = 1 r = [] for i in range (len(e)): c = 0 for j in range (len(r)): if e[i] == r[j]: c+=1 if c == 0 and j + 1 == len(r): count += 1 r.append(e[i]) print(count) (выдает "программа выполнялась слишком долго и была прервана")
0 0
Перейти к ответам

Ответы на вопрос

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

Ответ:

e = list(map(int, input().split()))

xcount=0

for i in range(len(e)):

   count=-1

   for x in range(len(e)):

       if e[i]==e[x]:

           count+=1

   if not count:

       xcount+=1

print(xcount)

Объяснение:

Ваш исходный код не до конца понял, т.к утерялись все пробелы, не смог восстановить

0 0
Отвечает нейросеть ChatGpt. Будьте внимательны, ответы нейросети могут содержать ошибочные или выдуманные данные.

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

Вместо этого вы можете использовать множество (set) для хранения уникальных элементов из списка. Множество автоматически удаляет повторяющиеся элементы, поэтому вы сможете легко определить количество различных элементов. Вот исправленный вариант:

python
e = list(map(int, input().split())) unique_elements = set(e) count = len(unique_elements) print(count)

Этот код сначала преобразует входные данные в список e, а затем создаст множество unique_elements, которое содержит только уникальные элементы из e. Затем вы можете использовать функцию len() для определения количества уникальных элементов в списке и вывести результат. Этот метод гораздо более эффективен и быстрее, чем использование вложенных циклов.

0 0

Похожие вопросы

Топ вопросов за вчера в категории Информатика

Последние заданные вопросы в категории Информатика

Задать вопрос