Задача на логику. Два города
В некоторой стране есть два города. В одном из них живут только люди, которые всегда говорят правду, в другом - только те, кто всегда лжет. Все они ходят друг к другу в гости, т.е. в любом из этих двух городов можно встретить как честного человека, так и лжеца.
Предположим, вы оказались в одном из этих городов. Как, задав один-единственный вопрос первому встречному, определить, в какой город вы попали?
#логическаязадача
В некоторой стране есть два города. В одном из них живут только люди, которые всегда говорят правду, в другом - только те, кто всегда лжет. Все они ходят друг к другу в гости, т.е. в любом из этих двух городов можно встретить как честного человека, так и лжеца.
Предположим, вы оказались в одном из этих городов. Как, задав один-единственный вопрос первому встречному, определить, в какой город вы попали?
#логическаязадача
❤1
Ответ к задаче "Два города"
Нужно просто спросить, живет ли человек в этом городе. Если он ответит "да", то это город честных. Если "нет" - город лжецов.
#логическаязадача
Нужно просто спросить, живет ли человек в этом городе. Если он ответит "да", то это город честных. Если "нет" - город лжецов.
#логическаязадача
🤣3❤1🤯1💅1
Задача для новичков
Напишите функцию
Пример работы данной функции:
#задача #coding
Напишите функцию
findMissedNumbers()
, на вход которой подается список длинной n
, состоящий из целых чисел в диапазоне от 1
до n
. Данная функция должна вернуть список всех чисел, которые отсутствуют во входящем списке, но входят в диапазон от 1
до n
.Пример работы данной функции:
findMissedNumbers([4,3,2,7,8,2,3,1]) --> [5, 6]
findMissedNumbers([1, 1, 1]) --> [2, 3]
Свои варианты пишите в комментариях! Решение - сегодня вечером.#задача #coding
❤1👍1
Ответ к предыдущей задаче для новичков
def findMissedNumbers(nums: list[int]) -> list[int]:
return [i for i in range(1, len(nums) + 1) if i not in nums]
А вот более быстрый вариант, который работает за линейное время:def findMissedNumbers(nums: list[int]) -> list[int]:
return list(set(range(1, len(nums) + 1)) - set(nums))
#задача #coding🔥5👍2
Tips & Tricks. Как проверить наличие ключа в словаре в Python
В этом уроке мы рассмотрим четыре наиболее часто используемых способа проверки существования ключа в словаре на языке Python.
#tipsandtricks #словари
В этом уроке мы рассмотрим четыре наиболее часто используемых способа проверки существования ключа в словаре на языке Python.
#tipsandtricks #словари
👍5
Задача с кодом. Бит четности
Биты четности используются для проверки того, не были ли нарушены двоичные данные в ходе передачи. Работают они следующим образом:
- Если двоичная строка содержит нечетное количество единиц, бит четности — 1.
- Если двоичная строка содержит четное количество единиц, бит четности — 0.
- Бит четности добавляется в конец двоичной строки.
Задание
Создайте функцию, которая будет при помощи битов четности проверять, валидна ли двоичная строка.
Рабочий пример
Другие примеры
Решение на нашем сайте.
#задача #coding
Биты четности используются для проверки того, не были ли нарушены двоичные данные в ходе передачи. Работают они следующим образом:
- Если двоичная строка содержит нечетное количество единиц, бит четности — 1.
- Если двоичная строка содержит четное количество единиц, бит четности — 0.
- Бит четности добавляется в конец двоичной строки.
Задание
Создайте функцию, которая будет при помощи битов четности проверять, валидна ли двоичная строка.
Рабочий пример
validate_binary("10110010") ➞ True
# Последняя цифра - бит четности.
# 0 - последняя цифра.
# 0 означает, что число единиц должно быть четным.
# Здесь 4 единицы.
# Возвращаем True.
Другие примеры
validate_binary("00101101") ➞ TrueПримечание: в инпуте всегда будет 8 символов (байт).
validate_binary("11000000") ➞ True
validate_binary("11000001") ➞ False
Решение на нашем сайте.
#задача #coding
❤3🔥2
Tips & Tricks. Замер времени выполнения куска кода
Модуль timeit позволяет замерить время выполнения любого куска кода.
#tipsandtricks #модули
Модуль timeit позволяет замерить время выполнения любого куска кода.
#tipsandtricks #модули
Задача на логику. Четыре человека, один подвесной мост и зомби, следующие по пятам
Студент, лаборантка, уборщик и старый профессор бегут от зомби. Впереди у них подвесной мост. Если они успеют его перейти, смогут обрезать веревки и оторваться от зомби. Но!
Все беглецы движутся с разной скоростью: студент может перебежать мост за минуту, лаборантка — за 2 минуты, уборщику понадобится 5 минут, старый профессор доковыляет за 10.
Профессор подсчитал, что зомби доберутся до моста через 17 минут. А мост одновременно может выдержать только двоих! Да еще и ночь: ничего не видно. У группы есть только один фонарь, и им придется передавать его друг другу, потому что у идущих по мосту (одного или двоих) фонарь должен быть обязательно.
Как всем успеть перейти через мост до прихода зомби?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Студент, лаборантка, уборщик и старый профессор бегут от зомби. Впереди у них подвесной мост. Если они успеют его перейти, смогут обрезать веревки и оторваться от зомби. Но!
Все беглецы движутся с разной скоростью: студент может перебежать мост за минуту, лаборантка — за 2 минуты, уборщику понадобится 5 минут, старый профессор доковыляет за 10.
Профессор подсчитал, что зомби доберутся до моста через 17 минут. А мост одновременно может выдержать только двоих! Да еще и ночь: ничего не видно. У группы есть только один фонарь, и им придется передавать его друг другу, потому что у идущих по мосту (одного или двоих) фонарь должен быть обязательно.
Как всем успеть перейти через мост до прихода зомби?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
👍11
Тест. Числовой тип в Python
Числовой тип в Python довольно прост и интуитивно понятен. Но, разумеется, прост он для тех, кто разобрался в теме. А вы хорошо разобрались? Проверьте: пройдите наш тест!
#тест
Числовой тип в Python довольно прост и интуитивно понятен. Но, разумеется, прост он для тех, кто разобрался в теме. А вы хорошо разобрались? Проверьте: пройдите наш тест!
#тест
🤡1
Как работает функция return() в Python?
Для получения значения из функции в языках программирования обычно используется оператор return(). Точно так же и в Python оператор return() используется для выхода из функции и возврата значения из функции. В этом уроке мы рассмотрим различные способы использования return() в Python.
#функции
Для получения значения из функции в языках программирования обычно используется оператор return(). Точно так же и в Python оператор return() используется для выхода из функции и возврата значения из функции. В этом уроке мы рассмотрим различные способы использования return() в Python.
#функции
❤2👍1
Tips & Tricks. Unexpected exception
Разбираемся, как выводить информативные сообщения пойманных исключений.
#tipsandtricks
Разбираемся, как выводить информативные сообщения пойманных исключений.
#tipsandtricks
Задача на логику. Число 1000
Можете ли вы число 1000 выразить восемью одинаковыми цифрами? (Также можно пользоваться знаками действий).
#логическаязадача
Можете ли вы число 1000 выразить восемью одинаковыми цифрами? (Также можно пользоваться знаками действий).
#логическаязадача
👍1
Ответ к задаче "Число 1000"
888 + 88 + 8 + 8 + 8 = 1000.
(2222 - 222) / 2 = 1000.
Во втором решении цифру 2 можно заменить на любую другую (разумеется, кроме нуля).
#логическаязадача
888 + 88 + 8 + 8 + 8 = 1000.
(2222 - 222) / 2 = 1000.
Во втором решении цифру 2 можно заменить на любую другую (разумеется, кроме нуля).
#логическаязадача
👍4
Задача для новичков
У вас есть
Напишите функцию
Пример работы данной функции:
#задача #coding
У вас есть
n
монет, из которых нужно построить лестницу. Лестница состоит из k
рядов, в первом из которых строго одна монета, а в следующих на одну монету больше в каждом последующем. Соответственно, последний ряд может быть неполным. Вот пример такой лестницы:$Как видите, тут 4-й ряд неполон.
$ $
$ $ $
$ $ $
Напишите функцию
arrangeCoins()
, которая принимает на вход целое число n
(количество монет), а выводит количество полных рядов лестницы.Пример работы данной функции:
arrangeCoins(8) --> 3
arrangeCoins(5) --> 2
Свои варианты пишите в комментариях! Решение - сегодня вечером.#задача #coding
😁3
Модули. Как использовать модуль Pathlib
Все операционные системы имеют разные правила построения путей к файлам. Например, в Linux для путей используется косая черта (слэш, /), а в Windows — обратная косая черта (обратный слэш, \).
Эта небольшая разница может вызвать ряд проблем, если вы работаете над проектом и хотите, чтобы разработчики могли работать с вашим кодом и в других операционных системах.
К счастью, если вы программируете на Python, модуль Pathlib сделает за вас всю тяжелую работу. Он обеспечит одинаковую работу ваших путей к файлам в разных операционных системах.
#модули
Все операционные системы имеют разные правила построения путей к файлам. Например, в Linux для путей используется косая черта (слэш, /), а в Windows — обратная косая черта (обратный слэш, \).
Эта небольшая разница может вызвать ряд проблем, если вы работаете над проектом и хотите, чтобы разработчики могли работать с вашим кодом и в других операционных системах.
К счастью, если вы программируете на Python, модуль Pathlib сделает за вас всю тяжелую работу. Он обеспечит одинаковую работу ваших путей к файлам в разных операционных системах.
#модули
Задача с кодом. Число Керзона
Если 2^N+1 без остатка делится на 2*N+1, то число N считается числом Керзона.
Реализуйте функцию, которая будет принимать целое число
Примеры:
#задача #coding
Если 2^N+1 без остатка делится на 2*N+1, то число N считается числом Керзона.
Реализуйте функцию, которая будет принимать целое число
num
и возвращать True, если num
— число Керзона, и False — если нет.Примеры:
is_curzon(5) ➞ TrueРешение на нашем сайте.
# 2 ** 5 + 1 = 33
# 2 * 5 + 1 = 11
# 33 кратно 11
is_curzon(10) ➞ False
# 2 ** 10 + 1 = 1025
# 2 * 10 + 1 = 21
# 1025 не кратно 21
#задача #coding
👍7