[프로그래머스]숫자의 표현(Python)

2022. 9. 18. 21:59·CodingTest/Programmers

0. 문제 링크

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

 

프로그래머스

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

programmers.co.kr

 

1. 문제 설명

1) 1부터 n까지 연속된 자연수의 합이 n인 방법의 수 찾기

 

2. 입출력

# input
n = 15

# output
result = 4
"""
1 + 2 + 3 + 4 + 5 = 15
4 + 5 + 6 = 15
7 + 8 = 15
15 = 15
"""

 

3. 코드

첫 번째 코드

def solution(n):
    answer = 0

    for i in range(1, n + 1):           # 1부터 n+1까지 반복
        sum = 0                         # 연속된 자연수를 더한 합
        for j in range(i, n + 1):       # i부터 n+1까지 반복
            sum += j                    # 합에 자연수 더하기
            if sum > n:                 # 합이 n보다 크면
                pass                    # 나머지 반복문은 패스
            if sum == n:                # 합이 n 이면
                answer += 1             # 1가지 방법 찾음
                pass                    # 나머지 반복문은 패스

    return answer

 

실행 결과

문제의 조건만 읽고 순수하게 코드를 작성했는데 효율성 테스트를 통과하지 못했다

 

두 번째 코드

def solution(n):
    answer = []
    
    for i in range(1, n, 2):        # 홀수이면서
        if n % i == 0:              # n의 약수인 경우
            answer.append(i)

    return len(answer) + n % 2      # n이 홀수면 한 번 더 가능

 

실행 결과

a + (a+1) + ... + (a+k-1) = (2a+k-1) * (k/2) 식에서 a = (n/k) + (1-k)/2 를 이용하였다.

a가 자연수가 되려면 k는 n의 약수, 1-k는 2의 배수(짝수), 즉 k는 홀수가 되어야 한다.

따라서 k는 n의 약수이면서 홀수인 경우가 되어야 하므로 for 문으로 코드를 작성해준다.

문제에서 제시한 케이스인 15 의 경우 k=2일 때 한 번 더 가능하므로 n이 홀수일 때 하나를 추가한다.

 

5. Github

https://github.com/iihye/Algorithm/blob/main/Programmers/express_number.py

 

GitHub - iihye/Algorithm

Contribute to iihye/Algorithm development by creating an account on GitHub.

github.com

 

 

728x90
저작자표시 비영리 변경금지 (새창열림)

'CodingTest > Programmers' 카테고리의 다른 글

[프로그래머스]영어 끝말잇기(Python)  (1) 2022.09.30
[프로그래머스]공 이동 시뮬레이션(Python)  (0) 2022.09.22
[프로그래머스]올바른 괄호(Python)  (0) 2022.09.17
[프로그래머스]최솟값 만들기(Python)  (0) 2022.09.16
[프로그래머스]JadenCase 문자열 만들기(Python)  (0) 2022.09.15
'CodingTest/Programmers' 카테고리의 다른 글
  • [프로그래머스]영어 끝말잇기(Python)
  • [프로그래머스]공 이동 시뮬레이션(Python)
  • [프로그래머스]올바른 괄호(Python)
  • [프로그래머스]최솟값 만들기(Python)
iihye_
iihye_
  • iihye_
    hye-log
    iihye_
    • 분류 전체보기 (296)
      • Development (19)
        • Spring (4)
        • Python (5)
        • React (4)
        • Next.js (1)
        • JavaScript (4)
        • CSS (1)
      • Infra (15)
        • Docker (1)
        • Jenkins (2)
        • Nginx (3)
        • JBoss (1)
        • Windows (3)
        • Linux (3)
        • Kafka (2)
      • Database (1)
        • MongoDB (1)
      • Tools (2)
        • Git (0)
        • Github (1)
        • Document (1)
      • CodingTest (125)
        • Programmers (38)
        • Baekjoon (52)
        • SWEA (27)
        • Jungol (4)
        • Codetree (1)
        • Goorm (3)
      • Education (99)
        • SSAFY 10기 (5)
        • AI Tech 4기 (94)
      • NomadCoder (35)
        • (JS)크롬 앱 만들기 (35)
      • Notice (0)
  • 링크

    • Github
  • 인기 글

  • 최근 글

  • 전체
    오늘
    어제
  • hELLO· Designed By정상우.v4.10.5
iihye_
[프로그래머스]숫자의 표현(Python)
상단으로

티스토리툴바