Напишите функцию, подсчитывающую количество одинаковых цифр в числе.
Условия:
- функция принимает число (исходим из того, что числа будут целыми и положительными)
- каждая цифра заменяется на число вхождений этой цифры в число
- итоговое число, возвращаемое функцией, должно быть целым числом, а не строкой.
Разбор примера
digit_count(136116) ➞ 312332 # Цифра 1 появляется трижды, поэтому все единицы заменяются на тройки. # Цифра 3 появляется только один раз, поэтому тройка заменяется единицей. # Цифра 6 появляется дважды, поэтому обе шестерки заменяются двойками. # Возвращается целое число.
Другие примеры
digit_count(221333) ➞ 221333 digit_count(136116) ➞ 312332 digit_count(2) ➞ 1
Варианты решений
def digit_count(n): n = str(n) return int(''.join(str(n.count(i)) for i in n))
def digit_count(n): num_counts = dict() str_n = str(n) for x in str_n: if x not in num_counts: num_counts[x] = 1 else: num_counts[x] += 1 return int( "".join( str(num_counts[x]) for x in str_n ) )