Как проверить кратность числа в python



Скачай курс
в приложении
Перейти в приложение
Открыть мобильную версию сайта
© 2013 — 2023. Stepik
Наши условия использования и конфиденциальности

Public user contributions licensed under cc-wiki license with attribution required
Кратна ли цифра цифре слева?
Напишите функцию, которая будет принимать число n и проверять, кратна ли каждая его цифра цифре, стоящей слева от нее. Верните массив булевых значений результатов проверок.
Примеры
divisible_by_left(73312) ➞ [False, False, True, False, True] # no element left to 7 = False # 3/7 = False # 3/3 = True # 1/3 = False # 2/1 = True divisible_by_left(1) ➞ [False] divisible_by_left(635) ➞ [False, False, False]
Примечание: массив всегда будет начинаться с False, поскольку слева от первой цифры ничего нет.
Варианты решений
def divisible_by_left(n): n = str(n) res = [False] for i in range(1,len(n)): if int(n[i-1]) == 0 or int(n[i]) % int(n[i-1]) != 0: res.append(False) else: res.append(True) return res
def divisible_by_left(n): Answer = [] Answer.append(False) Text = str(n) First = 0 Second = 1 Length = len(Text) while (Second < Length): Top = int(Text[Second]) Bottom = int(Text[First]) if (Bottom == 0) or (Top % Bottom != 0): Answer.append(False) First += 1 Second += 1 else: Answer.append(True) First += 1 Second += 1 return Answer
Как проверить кратность числа в python
Профиль
Группа: Участник
Сообщений: 59
Регистрация: 3.5.2006
Репутация: нет
Всего: нет
мне надо узнать например, делится ли число Х на 5 нацело? как сделать?
по-любому в библиотеке какой-то есть. только я вот не знаю =\
| Дата 2.12.2008, 08:35 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Участник
Сообщений: 45
Регистрация: 16.4.2007
Репутация: нет
Всего: нет
| Дата 2.12.2008, 13:06 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Завсегдатай
Сообщений: 1698
Регистрация: 28.11.2007
Репутация: 13
Всего: 41
маленький примерчик
| Код |
| #include //--------------------------------------------------------------------------- bool mycheck(int x, int y) if ((x%y)==0) return (true); else return false; > |
Это сообщение отредактировал(а) Dmi3ev - 2.12.2008, 13:56
| Дата 2.12.2008, 13:44 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Участник
Сообщений: 59
Регистрация: 3.5.2006
Репутация: нет
Всего: нет
Извините пожалуйста.
1. что такое mycheck?
2. а если не int? ведь нельзя же % использовать с double..
| Дата 2.12.2008, 13:56 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Завсегдатай
Сообщений: 1698
Регистрация: 28.11.2007
Репутация: 13
Всего: 41
| Цитата |
| 2. а если не int? ведь нельзя же % использовать с double.. |
а какой у тебя будет остаток от деления 2,5 на 5 допустим. может ты имеешь ввиду проверку деления нацело?
допустим x=4,2 а y=2,1, тогда x/y=2, это кратно или нет?
а если y=5? тогда чего? объясни подробнее
| Дата 2.12.2008, 13:58 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Участник
Сообщений: 59
Регистрация: 3.5.2006
Репутация: нет
Всего: нет
идет инремент массива бесконечно много раз list[index]. index++;
каждый раз, когда index/5 = целое чило 1,2,3,4,5,6,7.
, надо делать \n
| Дата 2.12.2008, 14:02 (ссылка) | (нет голосов) Загрузка . |
Профиль
Группа: Завсегдатай
Сообщений: 1698
Регистрация: 28.11.2007
Репутация: 13
Всего: 41
| Цитата |
| каждый раз, когда index/5 = целое чило |
значит index целое число))) не так ли??
Добавлено через 1 минуту и 11 секунд
| Цитата |
| 1. что такое mycheck? |
функция проверки кратности, которая написана над main, если кратно, то тогда возвращает true
Добавлено через 12 минут и 25 секунд
если число не int, а double и надо узнать делится ли на цело одно на другое, то:
| Код |
| #include //--------------------------------------------------------------------------- bool mycheck(double x, double y) if (x/y==int(x/y)) return (true); else return (false); > //--------------------------------------------------------------------------- int main(int argc, char* argv[]) //. double d; double ch=5.5; coutcin>>d; (mycheck (d, ch))? (cout//. return 0; > //--------------------------------------------------------------------------- |
Python: Комбинирование операций и функций
Логические операции — это выражения, значит, их можно комбинировать с другими выражениями. Например, мы хотим проверить четность числа — кратность двум. В программировании используют такой подход: проверяют остаток от деления на два:
- если остаток 0 — число четное
- если остаток не 0 — число нечетное
Остаток от деления — простая, но важная концепция в арифметике, алгебре, в теории чисел и криптографии. Нужно разделить число на несколько равных групп, и если в конце что-то останется — это остаток от деления.
Делим конфеты поровну между людьми:
- 7 конфет, 2 человека: 2 x 3 + остаток 1 — 7 не кратно 2
- 21 конфету, 3 человека: 3 x 7 + остаток 0 — 21 кратно 3
- 19 конфет, 5 человек: 5 x 3 + остаток 4 — 19 не кратно 5
Оператор % вычисляет остаток от деления:
- 7 % 2 → 1
- 21 % 3 → 0
- 19 % 5 → 4
Скомбинируем в одном выражении логический оператор «проверка равенства» == и арифметический оператор % и напишем функцию проверки четности:
def is_even(number): return number % 2 == 0 print(is_even(10)) # => True print(is_even(3)) # => False
Приоритет арифметических операций выше логических. Значит, сначала вычисляется арифметическое выражение number % 2 , а затем результат сравнивается с нулем и возвращается результат проверки равенства.
Теперь напишем функцию, которая принимает строку и проверяет, начинается ли эта строка с латинской буквы a .
- Получим и запишем в переменную первый символ из строки-аргумента
- Сравним, равен ли символ латинской букве a
- Вернем результат
def is_first_letter_an_a(string): first_letter = string[0] return first_letter == 'a' print(is_first_letter_an_a('orange')) # => False print(is_first_letter_an_a('apple')) # => True
Чтобы было понятно, что тут происходит, попробуйте проговорить происходящее аналогично тому, как мы расшифровывали процесс в примере с is_even() .
Теперь вы знаете, что операции сравнения применяются в программировании наравне с арифметическими. Но помните, что равенство обозначается == . Так вы не спутаете эту операцию с присваиванием значения переменной.
Задание
Реализуйте функцию is_international_phone() , которая принимает на вход строку - номер телефона и проверяет его формат. Если телефон начинается с +, значит это международный формат.
is_international_phone('89602223423') # False is_international_phone('+79602223423') # True
Упражнение не проходит проверку — что делать?
Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:
- Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.
В моей среде код работает, а здесь нет
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Мой код отличается от решения учителя
Это нормально , в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.
В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Прочитал урок — ничего не понятно
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.
Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.
Полезное
Определения
- Выражение — последовательность действий над данными, приводящая к каком-то результату, который можно использовать.
Как проверить кратность числа в python



Скачай курс
в приложении
Перейти в приложение
Открыть мобильную версию сайта
© 2013 — 2023. Stepik
Наши условия использования и конфиденциальности

Public user contributions licensed under cc-wiki license with attribution required
как узнать кратность чисел на python [закрыт]
Закрыт. Этот вопрос необходимо уточнить или дополнить подробностями. Ответы на него в данный момент не принимаются.
Хотите улучшить этот вопрос? Добавьте больше подробностей и уточните проблему, отредактировав это сообщение.
Закрыт 3 года назад .
Как можно найти все числа меньше 1000 кратные 3 и 5 с помощью кода на python
Отслеживать
Умник Умник
задан 5 ноя 2020 в 13:45
Умник Умник Умник Умник
11 1 1 золотой знак 1 1 серебряный знак 2 2 бронзовых знака
Т.е. делится ли число на 15?
– user361068
5 ноя 2020 в 13:48
Можно сразу на 15 проверять или даже сразу с шагом 15 пробегать, как заметил EOF, либо в лоб: print([n for n in range(100) if n % 3 == 0 and n % 5 == 0]) (если хотите что-то этим сказать)
5 ноя 2020 в 13:52
Я перепутал вот такая задача
5 ноя 2020 в 14:09
1 ответ 1
Сортировка: Сброс на вариант по умолчанию
for x in range(15, 1000, 15): print(x)
Отслеживать
ответ дан 5 ноя 2020 в 13:51
user361068 user361068
-
Важное на Мете
Похожие
Дизайн сайта / логотип © 2024 Stack Exchange Inc; пользовательские материалы лицензированы в соответствии с CC BY-SA . rev 2024.1.8.3130
Нажимая «Принять все файлы cookie» вы соглашаетесь, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.
Кратна ли цифра цифре слева?
Напишите функцию, которая будет принимать число n и проверять, кратна ли каждая его цифра цифре, стоящей слева от нее. Верните массив булевых значений результатов проверок.
Примеры
divisible_by_left(73312) ➞ [False, False, True, False, True] # no element left to 7 = False # 3/7 = False # 3/3 = True # 1/3 = False # 2/1 = True divisible_by_left(1) ➞ [False] divisible_by_left(635) ➞ [False, False, False]
Примечание: массив всегда будет начинаться с False, поскольку слева от первой цифры ничего нет.
Варианты решений
def divisible_by_left(n): n = str(n) res = [False] for i in range(1,len(n)): if int(n[i-1]) == 0 or int(n[i]) % int(n[i-1]) != 0: res.append(False) else: res.append(True) return res
def divisible_by_left(n): Answer = [] Answer.append(False) Text = str(n) First = 0 Second = 1 Length = len(Text) while (Second < Length): Top = int(Text[Second]) Bottom = int(Text[First]) if (Bottom == 0) or (Top % Bottom != 0): Answer.append(False) First += 1 Second += 1 else: Answer.append(True) First += 1 Second += 1 return Answer
FoxiMaxik / Вычисление кратности числа.py
Clone via HTTPS Clone with Git or checkout with SVN using the repository’s web address.
Learn more about clone URLs
Вычисление кратности числам 3 и 5 на Питоне.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
| R = int ( input ( " Введите целое число для определения кратности этого числа числам 3 и 5. " )) |
| if R % 3 != 0 : |
| q = 1 |
| else : |
| q = 0 |
| if R % 5 != 0 : |
| w = 1 |
| else : |
| w = 0 |
| if int ( q ) == int ( w ): |
| print ( "Число" , R , "некратно числам 3 и 5." ) |
| elif int ( q ) > int ( w ): |
| print ( "Число" , R , "кратно только числу 5." ) |
| elif int ( q ) < int ( w ): |
| print ( "Число" , R , "кратно только числу 3." ) |
| else : |
| print ( "Число" , R , "кратно числам 3 и 5." ) |
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment