[BOJ/백준] 1788 피보나치 수의 확장 (S3)

2024. 7. 3. 23:02· Algorithm PS/Baekjoon Online Judge
목차
  1. 문제
  2. 풀이
  3. Code

문제

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

풀이

피보나치 수열을 변형한 문제로 규칙을 구하면 쉽게 풀 수 있다. 

n의 값이 짝수이며 음수인 경우, 결과값이 음수로 나온다. n의 값에 대한 F(n)의 결과의 절대값은 n이 음수일 때와 양수일 때가 동일하다.

Code

import java.io.*;

public class Main {

    public static void main(String[] args) throws IOException {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        int n = Integer.parseInt(br.readLine());

        // n이 짝수인 경우에만 음수
        if (n < 0 && n % 2 == 0) bw.write("-1\n");  // n이 음수이고 짝수인 경우 -> F(n)=음수
        else if(n == 0) bw.write("0\n");
        else bw.write("1\n");

        n = Math.abs(n);  // 어차피 절대값으로 출력해야 되므로(n의 값이 짝수든 홀수든 절댓값은 동일)
        bw.write(fibonacci(n) + "");
        bw.flush();
        bw.close();
    }

    public static long fibonacci(int n) {
        if (n == 0) return 0;
        if (n == 1) return 1;

        long[] dp = new long[n+1];

        dp[0] = 0;
        dp[1] = 1;

        for (int i = 2; i <= n; i++) {
            dp[i] = (dp[i-1] + dp[i-2]) % 1000000000;  // 일반적인 피보나치와 동일
        }
        return dp[n];
    }
}

728x90

'Algorithm PS > Baekjoon Online Judge' 카테고리의 다른 글

[BOJ/백준] 5567 결혼식 (S2)  (0) 2024.07.05
[BOJ/백준] 11726 2×n 타일링 (S3)  (0) 2024.07.03
[BOJ/백준] 9251 LCS (G5)  (0) 2024.05.23
[BOJ/백준] 11053 가장 긴 증가하는 부분 수열 (S2)  (0) 2024.05.23
[BOJ/백준] 9657 돌 게임 3 (S3)  (0) 2024.05.22
  1. 문제
  2. 풀이
  3. Code
'Algorithm PS/Baekjoon Online Judge' 카테고리의 다른 글
  • [BOJ/백준] 5567 결혼식 (S2)
  • [BOJ/백준] 11726 2×n 타일링 (S3)
  • [BOJ/백준] 9251 LCS (G5)
  • [BOJ/백준] 11053 가장 긴 증가하는 부분 수열 (S2)
kyung.Kh
kyung.Kh
kyung.Kh
Dev..studynote
kyung.Kh
전체
오늘
어제
07-29 11:19
  • 분류 전체보기 (76) N
    • Algorithm PS (32)
      • Baekjoon Online Judge (32)
      • Programmers (0)
    • Computer Science (8)
      • Databse (2)
      • Operating System (1)
      • Computer Network (0)
      • Computer Architecture (0)
      • Algorithm (4)
      • Java & Spring (1)
    • Spring (29)
      • Spring Boot (1)
      • 스프링 핵심 원리 - 기본편(인프런 김영한) (7)
      • Java (1)
      • 자바 ORM 표준 JPA 프로그래밍 (20)
    • Project (3) N
      • 문제 & 해결 (2)
      • 개인 프로젝트 (1) N
    • Book (3)
      • 객체지향의 사실과 오해 (3)
    • 우하한테크코스 (1)
      • precourse (1)

최근 글

인기 글

블로그 메뉴

    태그

    • JPA
    • 재귀
    • Graph
    • BFS
    • 그리디
    • dfs
    • DP
    • 스프링 김영한
    • 구현
    • 스프링
    • 스프링부트
    • 인프런
    • 스프링 기본편
    • 객체지향
    • Union-Find
    • 해시를 사용한 집합과 맵
    • springboot
    • 알고리즘
    • Spring
    • 백준
    hELLO · Designed By 정상우.v4.2.2
    kyung.Kh
    [BOJ/백준] 1788 피보나치 수의 확장 (S3)
    상단으로

    티스토리툴바

    단축키

    내 블로그

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

    블로그 게시글

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

    모든 영역

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

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