코딩문제풀이/파이썬

[프로그래머스] 기사단원의 무기 (파이썬)

오늘밤공부 2023. 3. 17. 10:00
반응형

🗓️ 문제 설명

  • 숫자나라 기사단의 각 기사에게는 1부터 number까지 번호가 지정되어 있습니다.
  • 각 기사는 자신의 기사 번호의 약수 개수가 해당하는 공격력을 가진 무기를 구매하려 합니다.
  • 단, 이웃나라와의 협약에 의해 공격력의 제한수치를 정하고, 제한수치보다 큰 공격력을 가진 무기를 구매해야 하는 기사는 협약 기관에서 정한 공격력을 가지는 무기를 구매해야 합니다.
  • 무기를 만들 때는 무기의 공격력 1당 1kg의 철이 필요합니다.
  • 기사단원의 수를 나타내는 정수 number와 이웃나라와 협약으로 정해진 공격력의 제한수치를 나타내는 정수 limit와 제한수치를 초과한 기사가 사용할 무기의 공격력을 나타내는 정수 power가 주어졌을 때, 필요한 철의 무게를 반환하세요.
  • 제한 사항
    • 1 ≤ number ≤ 100000
    • 2 ≤ limit ≤ 100
    • 1 ≤ power ≤ limit
  • 입출력 예시
number limit power result
5 3 2 10
10 3 2 21

 

💻 코드

최종 코드

  • 수정사항
    >> 약수를 반복문 숫자의 제곱근까지만 구하고, 약수의 개수에 2를 곱해줌
    >> 반복문의 숫자가 제곱수일 경우 약수의 개수 * 2에서 1을 빼줌

 

코드 풀이

 

 

⚙️ 시행착오

1차 시도

더보기
  • 테스트 결과 : 시간초과 발생

 

 

반응형