조회 수 510 추천 수 0 댓글 0

#include <stdio.h>

int chair_g[40]={0}; //고정석 위치
int chair_cut[40]={0}; //고정석으로 인해 끊긴 구간의 각 개수
int num[41]={0, 1, 2, 0}; //좌석 개수 별 경우의 수
int max;

int cut_set(int n, int m); //고정석으로 인해 끊긴 구간의 각 개수 계산
void num_set(void); //좌석 개수 별 경우의 수 계산
int cal(int m); //각 구간별 계산 값 곱하기
int main(void)
{
	int i, n, m, m2, result; //n=좌석의 수 m=고정석의 수

	scanf("%d %d", &n, &m);

	for(i=0; i<m; i++)
	{
		scanf("%d", &chair_g[i]);
	}

	if(m!=0)
	{
		m2=cut_set(n, m);
	}
	else
	{
		m2=1;
		max=n;
		chair_cut[0]=n;
	}

	if(max==0)
		printf("1");
	else
	{
		num_set();


		result=cal(m2);

		printf("%d", result);
	}
	/*printf("\ncut: ");
	for(i=0; i<m2; i++)
	{
		printf("%d ", chair_cut[i]);
	}
	printf("\n");
	printf("num: ");
	for(i=0; i<=max; i++)
		printf("%d ", num[i]);
	printf("\n");*/
	return 0;
}
int cut_set(int n, int m)
{
	int i, c=0;

	for(i=0; i<=m; i++)
	{
		if(i==0 && chair_g[i]!=1)
			chair_cut[c]=chair_g[i]-1;

		else if(i!=0 && i!=m)
			chair_cut[c]=chair_g[i]-chair_g[i-1]-1;

		else if(i==m && chair_g[i-1]!=n)
		{
			//printf("chair_g[%d]=%d=============\n", i, chair_g[i]);
			chair_cut[c]=n-chair_g[i-1];
		}	


		if(max<chair_cut[c])
			max=chair_cut[c];

		if(chair_cut[c]!=0) c++;
	}

	return c;
}
void num_set(void)
{
	int i;

	for(i=3; i<=max; i++)
	{
		num[i]=num[i-1]+num[i-2];
	}
}
int cal(int m)
{
	int i, result=1;

	for(i=0; i<m; i++)
	{
		result*=num[chair_cut[i]];
	}

	return result;
}



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 747
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1507
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2854
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11243
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5172
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 9002
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19448
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38325
130 정올 배열1 형성평가4 정승준 2018.09.08 196
129 정올 기초다지기 출력 자가진단6 정승준 2018.01.06 195
128 테두리(승민) 승민 2016.11.12 194
127 정올 - 문제은행 - 과자게임(1319) 조정미 2018.06.30 193
126 정올 - 실전대비 - RESETO(1232) 조정미 2018.06.02 193
125 정올 배열1 형성평가6 정승준 2018.09.15 192
124 정올 - 알고리즘 - 짚신벌레(1822) - 미완2 조정미 2018.03.03 190
123 주사위(승민) 승민 2016.08.20 190
122 정올 반복제어문3 형성평가3 정승준 2018.03.10 188
121 정올 반복제어문2 형성평가A 정승준 2018.01.27 186
120 대덕마고 승민 2016.10.29 186
119 정올 - 실전대비 - PERKET(1127) 조정미 2018.06.02 185
118 535 : 선택제어문 - 자가진단8 adbdcd123 2018.08.25 183
117 테두리(승민) 승민 2016.11.12 183
116 정올 문자마름모 조정미 2017.11.18 182
115 124 : 선택제어문 - 형성평가5 adbdcd123 2018.08.25 179
114 함수2 자가진단7 선우 2016.07.09 179
113 정올 기초다지기 출력 자기진단7 정승준 2018.01.06 178
112 분수쇼 (승민) 승민 2016.07.23 178
111 for문 하나만 사용해서 일정수 몇번나오는지 구하는거(승민) 승민 2016.05.25 177
Board Pagination Prev 1 ... 15 16 17 18 19 20 21 22 23 24 ... 26 Next
/ 26