발효홍삼
코딩하는 홍삼
발효홍삼
전체 방문자
오늘
어제
  • 분류 전체보기 (142)
    • PS (63)
      • 프로그래머스 (9)
      • 코드업 (10)
      • 백준 (43)
      • 알고스팟 (1)
    • Programming Language (11)
      • html_css (2)
      • java (0)
      • c,c++ (2)
      • vanillajs (2)
      • react (0)
      • vue.js (0)
      • angular.js (0)
      • electron (3)
      • 엄랭(Umjunsik-lang) (1)
      • F# (1)
      • Node.js (0)
      • Go (0)
    • knowledge (41)
      • algorithm (3)
      • data structure (1)
      • os (1)
      • ML (1)
      • math (31)
      • paper review (0)
      • IT-license (4)
    • Programming Guide (27)
      • React (1)
      • Electron (2)
      • CSS , SASS ( SCSS ) , Tailw.. (3)
      • Node.js (1)
      • Go (1)
      • Ruby on Rails (2)
      • R (1)
      • PHP (1)
      • Docker (1)
      • JSP (1)
      • C# (1)
      • Django (1)
      • Flask (1)
      • Dart (1)
      • Next.js (1)
      • Vue.js (1)
      • Unity (1)
      • React Native (0)
      • Flutter (3)
      • GraphQL (1)
      • MongoDB (1)
      • .NET (1)
      • RUST (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 기초100제
  • 구현
  • 정보처리기능사 필기
  • 수학
  • C
  • electron
  • 미분
  • 코드업
  • 출력
  • nodejs
  • codeup
  • 파이썬
  • 정보처리기능사
  • 프로그래머스
  • Python
  • 백준
  • CSS
  • c++
  • HTML
  • java
  • 이산수학
  • 알고리즘
  • LV1
  • 자바
  • 기초백제
  • cpp
  • js
  • 미적분학
  • JavaScript
  • 적분

최근 댓글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
발효홍삼

코딩하는 홍삼

[ 백준 ] 1904번 : 01타일 - (c++/c, java/자바, python/파이썬)
PS/백준

[ 백준 ] 1904번 : 01타일 - (c++/c, java/자바, python/파이썬)

2022. 2. 17. 01:10
728x90
  • 문제

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


  • 알고리즘 ( 접근 )

N = 1 -> ans : 1 ( 1 )

N = 2 -> ans : 2 ( 00 , 11 )

N = 3 -> ans : 3 ( 001, 100, 111)

N = 4 -> ans : 5 ( 0011, 1111, 0000, 1100, 1001)

N = 5 -> ans : 8 ( 00111, 10011, 11001, 11100, 00001, 10000, 00100, 11111 )

 

N[i] = N[i-2] + N[i-1]

즉, 피보나치 수열로 풀 수 있다.


  • 풀이 - C++ / C
더보기
#include <iostream>

using namespace std;

int dp[1000001];
int n;

int main(void)
{
	cin >> n;
	dp[1] = 1; dp[2] = 2;
    
	for (int i = 3; i <= n; i++)
		dp[i] = dp[i - 2] % 15746  + dp[i - 1] % 15746;
	cout << dp[n] % 15746;

	return 0;
}
  • 풀이 - JAVA
더보기
import java.util.Scanner;

public class Main
{
    public static int dp[] = new int[1000001];
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        
        int n = sc.nextInt();
        
        dp[1] = 1; dp[2] = 2;
        for(int i = 3; i <= n; i++)
            dp[i] = dp[i-2] % 15746 + dp[i-1] % 15746;
        System.out.println(dp[n] % 15746);
    }
}
  • 풀이 - PYTHON
더보기
n = int(input())
dp = [0 for _ in range(1000001)] 

dp[1] = 1
dp[2] = 2

for i in range(3, n+1):
    dp[i] = (dp[i-1]+ dp[i-2]) % 15746

print(dp[n])
728x90
저작자표시 비영리 (새창열림)

'PS > 백준' 카테고리의 다른 글

[ 백준 ] 7568번 : 덩치 - (C++/C , JAVA/자바 , PYTHON / 파이썬)  (0) 2022.02.25
[ 백준 ] 2302번 : 극장 좌석 - (c++/c, java/자바, python/파이썬)  (0) 2022.02.17
[ 백준 ] 7576번 : 토마토 - (c++/c, java/자바, python/파이썬)  (0) 2022.02.14
[ 백준 ] 1271번 : 엄청난 부자2 - (python/파이썬, java/자바)  (0) 2022.02.02
[ 백준 ] 1004번 : 어린 왕자 - (c++, c, python/파이썬, java/자바)  (0) 2022.01.28
    'PS/백준' 카테고리의 다른 글
    • [ 백준 ] 7568번 : 덩치 - (C++/C , JAVA/자바 , PYTHON / 파이썬)
    • [ 백준 ] 2302번 : 극장 좌석 - (c++/c, java/자바, python/파이썬)
    • [ 백준 ] 7576번 : 토마토 - (c++/c, java/자바, python/파이썬)
    • [ 백준 ] 1271번 : 엄청난 부자2 - (python/파이썬, java/자바)
    발효홍삼
    발효홍삼
    코딩하는 홍삼

    티스토리툴바