Carnival7
Change Developer
Carnival7
전체 방문자
오늘
어제
  • 분류 전체보기
    • 자바의 정석
    • 프로그래밍 언어별 tools
      • 파이썬
      • 자바
    • 코딩 테스트
      • 백준 강의 기초편
      • 백준 강의 연습편
      • 백준 강의 문제편
      • 삼성 기출
      • 백준 - 일반
      • 카카오 기출
      • 프로그래머스 - 일반
      • 코테 풀이 Tools
    • CS
      • Network
      • 운영체제
      • 알고리즘
      • DB
    • Web_Backend
      • Spring
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술
      • 스프링 핵심 원리 - 기본편
    • DevOps
    • IT 업무 지식
      • 인프라
      • 클라우드
    • 자격증
      • AWS - CLF
      • 정처기 - 실기
    • 생각 정리

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 슬라이딩 윈도우
  • 스프링 #인터셉터 #AOP #필터
  • 스프링 부트 무중단 웹 서비스
  • Github Actions
  • code deploy
  • 알고리즘 #백준강의기초편 #코딩테스트
  • DMZ
  • DevOps
  • 코딩테스트 #삼성기출 #구현 #시뮬레이션
  • 프로그래머스 #카카오기출 #레벨2
  • ci/cd
  • 슬라이딩 윈도우 #덱
  • 삼성기출 #2023 #상반기
  • 삼성기출 #백준강의문제편
  • nginx
  • 스프링 #AOP

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

코딩 테스트/백준 강의 연습편

브루트포스) 1182.부분수열의 합

2022. 6. 7. 18:19

https://www.acmicpc.net/problem/1182

 

1182번: 부분수열의 합

첫째 줄에 정수의 개수를 나타내는 N과 정수 S가 주어진다. (1 ≤ N ≤ 20, |S| ≤ 1,000,000) 둘째 줄에 N개의 정수가 빈 칸을 사이에 두고 주어진다. 주어지는 정수의 절댓값은 100,000을 넘지 않는다.

www.acmicpc.net

n,s = map(int,input().split())
nums=list(map(int,input().split()))

answer=0

# solution 1
def dfs(index,arr,m):
    global answer
    # 정답을 찾은 경우
    if len(arr) == m:
        if sum(arr) == s:
            answer+=1
        return
    # 불가능한 경우
    if index==n:
        return

    dfs(index+1,arr+[nums[index]],m)
    dfs(index + 1, arr, m)

for i in range(1,n+1):
    dfs(0,[],i)

print(answer)

# solution 2
answer=0
def go(index,m):
    global answer
    if index==n:
        if m==s:
            answer+=1
        return
    go(index+1,m+nums[index])
    go(index+1,m)

go(0,0)
if s==0:
    answer-=1
print(answer)

'코딩 테스트 > 백준 강의 연습편' 카테고리의 다른 글

브루트포스) 15658.연산자 끼워넣기(2)  (0) 2022.06.07
브루트포스) 14888.연산자 끼워넣기  (0) 2022.06.07
브루트포스) 14225.부분수열의 합  (0) 2022.06.07
브루트포스) 6603. 로또  (0) 2022.06.07
브루트포스) 2580. 스도쿠  (0) 2022.06.07
    '코딩 테스트/백준 강의 연습편' 카테고리의 다른 글
    • 브루트포스) 14888.연산자 끼워넣기
    • 브루트포스) 14225.부분수열의 합
    • 브루트포스) 6603. 로또
    • 브루트포스) 2580. 스도쿠
    Carnival7
    Carnival7

    티스토리툴바