[백준 알고리즘] 16395번 / 파스칼의 삼각형
2021. 6. 3. 22:09ㆍ알고리즘/백준
728x90
반응형
SMALL
문제
파스칼의 삼각형은 이항계수를 삼각형 형태로 배열한 것인데, 블레즈 파스칼(1623-1662)을 따라 이름 붙여졌다.
단순한 형태로, 파스칼의 삼각형은 다음과 같은 방법으로 만들 수 있다.
- N번째 행에는 N개의 수가 있다.
- 첫 번째 행은 1이다.
- 두 번째 행부터, 각 행의 양 끝의 값은 1이고, 나머지 수의 값은 바로 위 행의 인접한 두 수의 합이다.
예를 들어, n=3이면 3번째 행의 2번째 수는 위 행의 인접한 두 수 (1과 1)을 더해서 만든다.
n=6일 때, 파스칼 삼각형의 6번째 행의 10은 5번째 행의 인접한 두 수(4와 6)을 더해서 구한다.
같은 방식으로 n=11일 때, 다음과 같은 파스칼의 삼각형을 만들 수 있다.
정수 n과 k가 주어졌을 때 파스칼의 삼각형에 있는 n번째 행에서 k번째 수를 출력하는 프로그램을 작성하시오.
이때, 이 수는 이항계수 C(n-1,k-1)임에 주의하시오.
입력
첫째 줄에 정수 n과 k가 빈칸을 사이에 두고 차례로 주어진다. 이 때, 1 ≤ k ≤ n ≤ 30을 만족한다.
출력
첫째 줄에 n번째 행에 있는 k번째 수를 출력한다.
입출력 예제
입력 | 출력 |
5 3 | 6 |
11 3 | 45 |
🌈 문제 풀이
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
import java.util.Scanner;
public class No16395_PascalsTriangle {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int k = sc.nextInt();
sc.close();
int[][] triangle = new int[n][];
for (int i = 0; i < triangle.length; i++) {
triangle[i] = new int[i+1];
}
for (int i = 0; i < n; i++) {
for (int j = 0; j <= i; j++) {
triangle[i][j] = 1;
if (i > 1 && j > 0 && j <= i-1) {
triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];
}
}
}
System.out.println(triangle[n-1][k-1]);
}
}
|
cs |
👩💻 풀어보기 👨💻 https://www.acmicpc.net/problem/16395
728x90
반응형
LIST
'알고리즘 > 백준' 카테고리의 다른 글
[백준 알고리즘] 11365번 / !밀비 급일 (0) | 2021.06.05 |
---|---|
[백준 알고리즘] 11655번 / ROT13 (0) | 2021.06.05 |
[백준 알고리즘] 2475번 / 검증수 (0) | 2021.05.31 |
[백준 알고리즘] 11653번 / 소인수분해 (0) | 2021.05.30 |
[백준 알고리즘] 1436번 / 영화감독 숌 (0) | 2021.05.30 |