씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

알고리즘/수열

자바(java)를 이용한 파스칼삼각형코드

2021. 5. 5. 10:51
728x90

우선 파스칼삼각형 이라고 한다면 첫번째 줄에는 1이 무조건 출력이됩니다.

 

두번째줄부터는 연산을 해야합니다.

첫번째줄에서는 연산을 할게 없어서 양쪽으로 1 1이 내려옵니다.

즉, 맨왼쪽과 맨오른쪽은 항상 1이 출력됩니다.

그다음 그사이에 들어갈 값을 위층의 숫자를 더한 값입니다.

 

package com.triangle;

import java.util.Scanner;

public class PascalTriangle {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		System.out.println("level : ");
		int n = sc.nextInt();
		
		int[][] arr = new int[n][];
		
		arr[0] = new int[] {1};
		for(int i = 1; i < arr.length; i++) {
			arr[i] = new int[i+1];
			
			for(int j = 0; j < arr[i].length; j++) {
				if(j==0 || j == arr[i].length-1) {
					arr[i][j] = 1;
				}else {
					arr[i][j] = arr[i-1][j-1] + arr[i-1][j];
					
				}
			}
		}
		prn(arr);
		
        sc.close();
        
	}
	
	private static void prn(int[][] arr) {
		for (int i = 0; i < arr.length; i++) {
			for(int j = arr.length; j > i; j--) {
				System.out.print("  ");
			}
			for(int j = 0; j < arr[i].length; j++) {
				System.out.printf("%4d", arr[i][j]);
			}
			System.out.println();
		}
	}
}

 

Scanner sc = new Scanner(System.in);
System.out.println("level : ");
int n = sc.nextInt();
		
int[][] arr = new int[n][];

숫자를 하나 입력받아서 몇층까지 출력할지를 정해줍니다.

 

 

arr[0] = new int[] {1};

for(int i = 1; i < arr.length; i++) {
	arr[i] = new int[i+1];
			
	for(int j = 0; j < arr[i].length; j++) {
		if(j==0 || j == arr[i].length-1) {
			arr[i][j] = 1;
		}else {
			arr[i][j] = arr[i-1][j-1] + arr[i-1][j];
					
		}
	}
}

기본값 1을 배열 첫번째 공간에 할당했기 때문에 입력받은 층수의 -1번만큼 반복해야합니다.

 

두번째 배열 공간부터는 해당 층수만큼 배열을 할당합니다.

(1번지 배열이면 2칸할당, 2번지 배열이면 3칸할당.... )

 

다시한번 반복문 for문을 이용하여 0번지는 1 끝번지도 1을 출력하고 0번지와 끝번지가 아닐경우에는 바로 윗층의 배열에 있는 숫자를 더합니다...

 

혹시 잘 이해가 안가시는 분들은 댓글달아주세요!

728x90
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바