Python. Решение задач на обработку целых чисел
В данной теме приведены примеры решения наиболее распространенных задач, связанных с обработкой чисел. Изучение темы предполагает базовые знания по основам языка Python, а именно, использование средств ввода/вывода, циклов, списков, функций и тому подобное.
Поиск на других ресурсах:
1. Выделить все цифры целого числа и представить их в виде списка
# Ввод числа n = input("n color: #ff0000;"># Выделить все цифры числа и представить их в виде списка # Результирующий список L = [] # Цикл формирования списка while n>0: number = n%10 # взять последнюю цифру L = [number] + L # прибавить цифру в список n = n/10 # убрать последнюю цифру из числа print("L color: #333300;">⇑2. Определить указанную цифру в целом числе
2.1. Позиция указывается слева
В примере определяется заданная цифра слева в заданном числе.
# Задача. Выделить цифру в числе по ее позиции # 1. Ввод числа n = input("n color: #ff0000;"># 2. Ввод позиции (начинается с 0) pos = input("pos color: #ff0000;"># 3. Сформировать список цифр числа L = [] # результирующий список # Цикл формирования списка L while n>0: L = [n%10] + L # взять последнюю цифру и прибавить цифру к списку n = n/10 # убрать последнюю цифру из числа # 4. Получить цифру num = L[pos] # 5. Вывести искомую цифру print("num color: #800080;">print("L color: #333300;">⇑2.2. Позиция задается справа
Если задан номер позиции справа (начиная с 0), то в предыдущем примере 2.1 строку
. # 4. Получить цифру num = L[pos] .
нужно заменить на строку
# 4. Получить цифру по смещению от конца num = L[len(L) - pos - 1]3. Вычислить сумму цифр целого числа
# Задача. Вычислить сумму цифр числа # 1. Ввод числа n = input ( "n color: #ff0000;"># 2. Вычислить сумму summ = 0 # Вычисляемая сумма # Цикл выделения цифр из числа и вычисление суммы while n>0: summ = summ + n%10 # взять последнюю цифру и прибавить цифру к сумме n = n/10 # убрать последнюю цифру из числа # 3. Вывести сумму print ( "sum color: #333300;">⇑
4. Инвертировать целое число (1234 => 4321)
Инвертировать число означает, что нужно получить новое число, которое читается как исходное число от конца до начала.
# Задача. Ивертировать число import math # 1. Ввод числа n = input ( "n color: #ff0000;"># 2. Создание нового инвертированного числа # 2.1. Сначала нужно вычислить количество цифр (порядок) в числе k = 0 n2 = n while n2>0: k = k+1 # увеличить счетчик количества цифр на 1 n2 = n2/10 # Убрать цифру # 2.2. Цикл выделения цифр из числа n и создание инвертированного числа while n>0: # взять последнюю цифру last = n%10 # уменьшить порядок числа k = k-1 # умножить полученную цифру на 10^k # и прибавить ее к новому числу n2 = n2 + int (last*math.pow(10, k)) # n2 - новое число # убрать последнюю цифру из числа n = n/10 # 3. Вывести новое число print ( "n2 color: #333300;">⇑
5. Функция GetNumCount() . Определить количество цифр в числе
Реализовать функцию GetNumCount() , которая определяет количество цифр в целом числе. Функция получает параметром исходное число.
# Задача. Определить количество цифр в числе import math # Функция GetNumCount() - определить количество цифр в числе def GetNumCount (n): k = 0 # k - результат while n>0: k = k+1 n = n/10 return k # Демонстрация работы функции # Ввод числа n = input ( "n color: #ff0000;"># Вызов функции k = GetNumCount(n) print ( "k color: #333300;">⇑
6. Функция GetMaxNum() . Определить максимальную цифру в числе
В заданном целом числе n (n>0) нужно определить максимальную цифру. Например, если есть число 2883345, то максимальная цифра будет 8.
# Задача. Определить максимальную цифру в числе import math # Функция GetMaxNum() - определить максимальную цифру в числе def GetMaxNum (n): # получить последнюю цифру числа Max = n%10 while n>0: n = n/10 # уменьшить число if Max < n%10: # сравнить последнюю цифру с максимумом Max = n%10 return Max # Демонстрация работы функции # Ввод числа n = input ( "n color: #ff0000;"># Вызов функции num = GetMaxNum(n) print ( "num color: #333300;">⇑
7. Функция GetMinNum() . Определить минимальную цифру в числе
Задача решается так же как и в предыдущем примере.
# Задача. Определить минимальную цифру в числе import math # Функция GetMinNum() - определить минимальную цифру в числе def GetMinNum (n): # получить последнюю цифру числа Min = n%10 while n>0: n = n/10 # уменьшить число if Min > n%10: # сравнить последнюю цифру с минимумом Min = n%10 return Min # Демонстрация работы функции # Ввод числа n = input ( "n color: #ff0000;"># Вызов функции num = GetMinNum(n) print ( "num color: #333300;">⇑
Связанные темы
Найти наибольшую цифру в десятичной записи числа
Напишите программу python, которая получает с клавиатуры натуральное число и находит наибольшую цифру в его десятичной записи.
Лучшие ответы ( 1 )
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
Ответы с готовыми решениями:Напишите функцию, которая возвращает последнюю цифру десятичной записи числа
1.Напишите функцию, которая возвращает последнюю цифру десятичной записи числа. 2.Напишите функцию.
Задано целое неотрицательное число. Определить последнюю цифру в десятичной записи этого числа
Задано целое неотрицательное число. Определить последнюю цифру в десятичной записи этого.Задано целое неотрицательное число. Определить последнюю цифру в десятичной записи этого числа(цикл с постусловием)
Помогите плз Задано целое неотрицательное число. Определить последнюю цифру в десятичной записи.
Напишите функцию, возвращающую последнюю цифру целого числа в десятичной записи. Не использовать операцию %
def TretieChislo(x)
Найти наибольшую цифру в десятичной записи натурального числа
Напишите программу, которая получает с клавиатуры натуральное число и находит наибольшую цифру в.Как найти наибольшее по сумме чисел?
Вводится N чисел.
Среди натуральных чисел, которые были введены,
найдите наибольшее по сумме цифр. Выведите на экран это число и сумму его цифр.
Сделал так, но что-то не особо рабочий.number_of_digits = int(input('Введите количество чисел: ')) max_m = 0 max_sum = 0 summ = 0 for i in range(number_of_digits): print('Введите число: ', end=' ') number = int(input()) this_num = number while number > 0: summ += number % 10 number //= 1 if summ > max_sum: max_sum = summ max_num = this_num summ = 0 print('Число', max_num, 'имеет максимальную сумму цифр:', max_sum) Прошу помощи в решении.
- Вопрос задан 08 февр.
- 1582 просмотра
1 комментарий
Простой 1 комментарий
Найти число с максимальной суммой цифр
Что я делаю: сначала нахожу сумму цифр числа, чтобы найти максимальное. По индексу максимального числа из полученных сумм хочу найти максимальное из array . До append все хорошо, но с индексом и нахождением числа проблема.
Отслеживать
12.5k 7 7 золотых знаков 18 18 серебряных знаков 48 48 бронзовых знаков
задан 22 апр 2021 в 10:25
Дарья Лазарева Дарья Лазарева
59 1 1 серебряный знак 8 8 бронзовых знаков
array = [120,125,365,450]; print(max(array)) (max() - встроенная функция пайтона)
22 апр 2021 в 10:28
Если бы так просто было))) Прочитайте мой комментарий.
22 апр 2021 в 10:32
или нужно вернуть не 450 (максимальное), а 365, у которого максимальная сумма цифр? ps по описанию как раз и не скажешь, что вы на самом деле хотите получить
22 апр 2021 в 10:32
Да 365 нужно вернуть
22 апр 2021 в 10:33
2 ответа 2
Сортировка: Сброс на вариант по умолчанию
Находим максимальный элемент массива array по ключу:
- Из числа 365 (к примеру) делаем список ['3', '6', '5'] .
- Находим сумму элементов списка sum(. ) , при этом переводя их в map(int, . ) .
array = [120, 125, 365, 450] print(max(array, key=lambda x: sum(map(int, str(x)))))
Отслеживать
ответ дан 22 апр 2021 в 10:36
13.1k 2 2 золотых знака 21 21 серебряный знак 37 37 бронзовых знаков
TypeError: 'int' object is not callable
22 апр 2021 в 10:38
@Jack_oS, еще раз проверьте 🙂
22 апр 2021 в 10:38
да, все ок, это что-то с pycharm было и его django console.
22 апр 2021 в 16:20
В дополнение к ответу от entithat.
Больше текста, но без зубодробительности однострочников пайтона 😉
# функция для определения суммы чисел def sum_nums(num): result = 0 # текущая сумма - 0 for ch in str(num): # для каждого элемента в числе, переведенном в строку: result += int(ch) # добавить инт элемента к результату return result # основная ф-ция def max_sum_num(arr): max_num = arr[0] # первый в списке - текущий максимальный max_sum = sum_nums(arr[0]) # то же для суммы for el in arr[1:]: # для каждого элемента, начиная со второго: el_sum = sum_nums(el) # вычислить сумму if el_sum > max_sum: # если больше текущей: max_num = el # обновить максимальное число max_sum = el_sum # обновить максимальную сумму return max_num
array = [120,125,365,450] max_sum_num(array)