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

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7
코딩 테스트/백준 강의 연습편

시뮬레이션과 구현) 16974.레벨 햄버거

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

시뮬레이션과 구현) 16974.레벨 햄버거

2022. 6. 9. 10:23

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

 

16974번: 레벨 햄버거

상근날드에서 오랜만에 새로운 햄버거를 출시했다. 바로 레벨-L 버거이다. 레벨-L 버거는 다음과 같이 만든다. 레벨-0 버거는 패티만으로 이루어져 있다. 레벨-L 버거는 햄버거번, 레벨-(L-1) 버거,

www.acmicpc.net

# solution.
# d[i] : 레벨 i 인 햄버거의 길이. d[i]=1+d[i-1]+1+d[i-1]+1=2d[i-1]+3
# p[i] : 레벨 i 인 햄버거의 패티 개수. p[i-1]+1+p[i-1]=2p[i-1]+1
# go(n,x) : 레벨 n 버거에서 아래 x장 중 패티의 개수 반환
# if n>=1:
#     x==1: 0
#     1<x<=1+d[n-1] : p[n-1]
#     x=1+d[n-1]+1 : p[n-1]+1
#     1+d[n-1]+1<x<=1+d[n-1]+1+d[n-1] : 2p[n-1]+1
#     x=1+d[n-1]+1+d[n-1]+1 : 2p[n-1]+1

n,x=map(int,input().split())

d=[0]*(n)
p=[0]*(n)
d[0]=1
p[0]=1

for i in range(1,n):
    d[i]=2*d[i-1]+3
    p[i]=2*p[i-1]+1

def go(n,x):
    if n==0:
        if x==0:
            return 0
        else:
            return 1
    else:
        if x==1:
            return 0
        elif 1<x<=1+d[n-1]:
            return go(n-1,x-1)
        elif x==d[n-1]+2:
            return p[n-1]+1
        elif d[n-1]+2<x<=2*d[n-1]+2:
            return p[n-1]+1+go(n-1,x-1-d[n-1]-1)
        else:
            return 2*p[n-1]+1

ans=go(n,x)
print(ans)

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

BFS) 1963. 소수 경로  (0) 2022.06.10
BFS) 6087.레이저 통신  (0) 2022.06.09
브루트포스) 16198.에너지 모으기  (0) 2022.06.07
브루트포스) 16197.두 동전  (0) 2022.06.07
브루트포스) 14500.테트로미노  (0) 2022.06.07
    '코딩 테스트/백준 강의 연습편' 카테고리의 다른 글
    • BFS) 1963. 소수 경로
    • BFS) 6087.레이저 통신
    • 브루트포스) 16198.에너지 모으기
    • 브루트포스) 16197.두 동전
    Carnival7
    Carnival7

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.