Algorithm/COS
[COS Pro 1급, Python] 5차 4번 : 각 숫자가 몇개가 있나요
JMcunst
2022. 2. 28. 16:55
728x90
반응형
문제 유형
한줄 수정(디버깅)
난이도
easy
Note
1. 문제 자체는 쉬웠다.
2. 하지만, 함수 구현 문제로 나올 수 있으니, 해당 로직은 알 필요가 있다.
3. while문 : 숫자를 자릿 수를 쪼개가면서 10으로 나눈 나머지 (0~9)를 number_count의 인덱스에 1씩 더해감. 흡사 collections 모듈의 Counter. 숫자라서 인덱스로 가능. 문자라면, Counter 적극 활용.
4. for문 : 출력.
Code
# -*- coding: utf-8 -*-
# UTF-8 encoding when using korean
def solution(number):
answer = ''
number_count = [0 for _ in range(10)]
while number > 0:
number_count[number % 10] += 1
number //= 10
for i in range(9, 0, -1):
if number_count[i] != 0:
answer += (str(i) + str(number_count[i]))
return answer
number1 = 2433
ret1 = solution(number1)
print("solution 함수의 반환 값은", ret1, "입니다.")
number2 = 662244
ret2 = solution(number2)
print("solution 함수의 반환 값은", ret2, "입니다.")
※ 가끔 코드 중 print(~)가 있습니다. 정리 못한 점 죄송합니다.
728x90
반응형