ye0nn
영차영차
ye0nn
전체 방문자
오늘
어제
  • 분류 전체보기 (61)
    • CS (0)
      • 운영체제 (0)
      • 네트워크 (0)
      • 알고리즘 & 자료구조 (0)
    • 코딩테스트 (48)
      • 프로그래머스 (40)
      • 백준 (8)
    • 프로그래밍 (11)
      • 프론트엔드 (3)
      • 자바스크립트 (0)
      • 스위프트 (7)
      • 파이썬 (1)
    • 취준기록 (1)

인기 글

블로그 메뉴

  • 홈
  • 태그
  • 방명록

티스토리

hELLO · Designed By 정상우.
ye0nn

영차영차

[프로그래머스] Level 2 - 타겟 넘버 (Python)
코딩테스트/프로그래머스

[프로그래머스] Level 2 - 타겟 넘버 (Python)

2022. 6. 4. 23:17

 

 

 

 

https://programmers.co.kr/learn/courses/30/lessons/43165

 

코딩테스트 연습 - 타겟 넘버

n개의 음이 아닌 정수들이 있습니다. 이 정수들을 순서를 바꾸지 않고 적절히 더하거나 빼서 타겟 넘버를 만들려고 합니다. 예를 들어 [1, 1, 1, 1, 1]로 숫자 3을 만들려면 다음 다섯 방법을 쓸 수

programmers.co.kr

 

 

 

 

✅ Solution

  • deque를 이용하여 idx가 numbers의 길이보다 작을 때만 +, - 의 경우를 모두 구해준다. 
  • 만약 idx가 numbers의 길이가 같은 경우에는 target값과 비교하여 같다면 answer에 1을 더해준다.

 

 

 

 

✅ Code

from collections import deque

def solution(numbers, target):
    answer = 0
    queue = deque()
    queue.append((0, 0))

    while queue:
        now, idx = queue.popleft()

        if idx < len(numbers):
            queue.append((now + numbers[idx], idx + 1))
            queue.append((now - numbers[idx], idx + 1))
        elif idx == len(numbers):
            if now == target:
                answer += 1

    return answer

 

 

 

 

저작자표시 (새창열림)

'코딩테스트 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] Level 2 - 괄호 회전하기 (Python)  (0) 2022.06.09
[프로그래머스] Level 2 - 짝지어 제거하기 (Python)  (0) 2022.06.04
[프로그래머스] Level 2 - 더 맵게 (Python)  (0) 2022.06.03
[프로그래머스] Level 2 - 주차 요금 계산 (Python)  (0) 2022.05.24
[프로그래머스] Level 2 - 양궁대회 (Python)  (2) 2022.05.24
    '코딩테스트/프로그래머스' 카테고리의 다른 글
    • [프로그래머스] Level 2 - 괄호 회전하기 (Python)
    • [프로그래머스] Level 2 - 짝지어 제거하기 (Python)
    • [프로그래머스] Level 2 - 더 맵게 (Python)
    • [프로그래머스] Level 2 - 주차 요금 계산 (Python)
    ye0nn
    ye0nn
    프론트엔드 개발자의 개발기록

    티스토리툴바