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

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

카테고리 없음

DP) 1309.동물원

2022. 2. 12. 23:05

문제 : 1309. 동물원

 

1309번: 동물원

첫째 줄에 우리의 크기 N(1≤N≤100,000)이 주어진다.

www.acmicpc.net

규칙

  1. 가로로 두 칸, 세로로 N칸인 동물원이 있다.
  2. 사자를 가로, 세로로 붙어 있게 배치하면 안된다.

목표

동물원에 사자를 배치하는 가능한 모든 경우의 수는?

Solution

  1. d[n][m] : 세로로 n칸인 우리에 배치할 때, n번째 줄은 m번 방법으로 배치하는 경우의 수
  2. m : 3개의 방법 중 하나.
    1) d[n][0] : n번 줄에 배치하지 않음
    2) d[n][1] : n번 줄의 왼쪽에 배치함
    3) d[n][2] : n번 줄의 오른쪽에 배치함
  3. 점화식
    1) d[n][0] = d[n-1][0] + d[n-1][1] + d[n-1][2]
    2) d[n][1] = d[n-1][0] + d[n-1][2]
    3) d[n][2] = d[n-1][0] + d[n-1][1]
  4. 답은 sum(d[n])

소스 코드

n=int(input())  
mod = 9901  

d=[[0] * 3 for _ in range(n+1)]  

d[1][0] = 1  
d[1][1] = 1  
d[1][2] = 1  

for i in range(2,n+1):  
    d[i][0] = d[i-1][0] + d[i-1][1] + d[i-1][2]  
  d[i][0] %= mod  
    d[i][1] = d[i-1][0] + d[i-1][2]  
  d[i][1] %= mod  
    d[i][2] = d[i-1][0] + d[i-1][1]  
  d[i][2] %= mod  

print(sum(d[n])%mod)
    Carnival7
    Carnival7

    티스토리툴바