2017.11.18 11:12

정올 파스칼삼각형

조회 수 513 추천 수 0 댓글 0

#include <stdio.h>

int result[30][30]={0};

void pr(int n, int m);
int Add1(int i, int j);
int Add2(int i, int j);
int Add3(int i, int j);
int F(int i, int j);
void one(int n);
void two(int n);
void three(int n);
int main(void)
{
	int n, m;
	scanf("%d %d", &n, &m);
	switch(m)
	{
		case 1:
			one(n);
			break;
		case 2:
			two(n);
			break;
		case 3:
			three(n);
			break;
	}
	pr(n, m);
	return 0;
}
void pr(int n, int m)
{
	int i, j;
	for(i=0; i<n; i++)
	{
		for(j=0; j<n; j++)
		{
			if(result[i][j]==0 && m!=2)
				break;
			else if(result[i][j]==0 && m==2)
				printf(" ");
			else
				printf("%d ", result[i][j]);
		}
		printf("\n");
	}
}
int F(int i, int j)
{
	if(i<0 || i>30 || j<0 || j>30)
		return 0;
	else
		return result[i][j];
}
int Add1(int i, int j)
{
	return F(i-1, j-1) + F(i-1, j);
}
void one(int n)
{
	int i, j;
	result[0][0]=1;
	for(i=1; i<n; i++)
	{
		for(j=0; j<=i; j++)
		{
			result[i][j]=Add1(i, j);
		}
	}
}
int Add2(int i, int j)
{
	return F(i+1, j+1) + F(i+1, j);
}
void two(int n)
{
	int i, j;
	result[n-1][n-1]=1;
	for(i=n-2; i>=0; i--)
	{
		for(j=n-1; j>=i; j--)
		{
			result[i][j]=Add2(i, j);
		}
	}
}
int Add3(int i, int j)
{
	return F(i, j+1) + F(i+1, j+1);
}
void three(int n)
{
	int i, j;
	result[n-1][n-1]=1;
	for(j=n-2; j>=0; j--)
	{
		for(i=n-1; i>=j; i--)
		{
			result[i][j]=Add3(i, j);
		}
	}
}



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 748
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1508
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2858
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11244
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5176
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 9006
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19450
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38327
50 정올 반복제어문3 자가진단5(반대) 정승준 2018.08.25 111
49 정올 배열1 자가진단7 정승준 2018.10.13 110
48 정올 배열1 형성평가2 정승준 2018.09.08 110
47 정올 배열2 자가진단5 정승준 2018.10.27 109
46 정올 반복제어문3 형성평가7 정승준 2018.08.25 109
45 dd 선우 2016.11.19 109
44 작은수 두배 큰수 절반 함수(승민) 승민 2016.07.16 109
43 정올 배열2 형성평가2 정승준 2018.11.17 108
42 정올 배열1 자가진단9 정승준 2018.10.13 107
41 정올 반복제어문3 자가진단4 정승준 2018.08.18 107
40 for문(승민) 승민 2016.03.05 107
39 정올 반복제어문3 형성평가3 정승준 2018.08.25 106
38 정올 반복제어문3 형성평가2 정승준 2018.08.25 104
37 A 20번 반복해서 출력하기(승민) 승민 2016.03.12 104
36 정올 배열1 형성평가A(반대) 정승준 2018.09.15 103
35 정올 배열1 형성평가8 정승준 2018.09.15 103
34 정올 배열1 자가진단4 정승준 2018.10.13 102
33 정올 배열1 자가진단3 정승준 2018.09.01 102
32 정올 배열2 형성평가8 정승준 2018.12.01 99
31 정올 배열2 형성평가8 정승준 2018.12.01 98
Board Pagination Prev 1 ... 17 18 19 20 21 22 23 24 25 26 Next
/ 26