프로그래머스/파이썬_입문

개미 군단

싱싱한복초이 2024. 10. 12. 15:44

https://school.programmers.co.kr/learn/courses/30/lessons/120837

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

[문제 설명]

개미 군단이 사냥을 나가려고 합니다. 개미군단은 사냥감의 체력에 딱 맞는 병력을 데리고 나가려고 합니다. 장군개미는 5의 공격력을, 병정개미는 3의 공격력을 일개미는 1의 공격력을 가지고 있습니다. 예를 들어 체력 23의 여치를 사냥하려고 할 때, 일개미 23마리를 데리고 가도 되지만, 장군개미 네 마리와 병정개미 한 마리를 데리고 간다면 더 적은 병력으로 사냥할 수 있습니다. 사냥감의 체력 hp가 매개변수로 주어질 때, 사냥감의 체력에 딱 맞게 최소한의 병력을 구성하려면 몇 마리의 개미가 필요한지를 return하도록 solution 함수를 완성해주세요.

 

제한사항

  • hp는 자연수입니다.
  • 0 ≤ hp ≤ 1000

[나의 풀이]

def solution(hp):
    a =[]
    a.append(hp // 5)
    a.append((hp % 5) //3)
    a.append((hp % 5) % 3)
    return sum(a)

 

[다른 풀이]

def solution(hp):
    answer = 0
    for ant in [5, 3, 1]:
        d, hp = divmod(hp, ant)
        answer += d
    return answer

나머지를 hp로 저장하여 다시 for loop를 돌리면 되는구나

def solution(hp):
    answer = 0
    answer += hp//5
    hp %= 5
    answer += hp//3
    hp %= 3
    answer += hp//1

    return answer

 

 

'프로그래머스 > 파이썬_입문' 카테고리의 다른 글

가위 바위 보  (0) 2024.10.12
모스부호(1)  (0) 2024.10.12
순서쌍의 개수  (0) 2024.10.11
진료 순서 정하기  (0) 2024.10.11
배열 자르기  (0) 2024.10.11