조회 수 465 추천 수 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 492
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1247
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2563
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10535
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4908
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8495
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19129
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38045
248 n/2 n-1 더해서 배열에넣고 원하는 수 빼기(승민) 승민 2016.08.20 127
247 n자리수 각자리수 제곱해서 더하기(승민) 승민 2016.08.20 878
246 홀수면 n수까지 홀수 출력 짝수면 n수까지 짝수 출력(승민) 승민 2016.08.20 458
245 n개수의 주사위 돌리기(승민) 승민 2016.08.20 446
244 주사위(승민) 승민 2016.08.20 169
243 세자리수 곱해서 각자리수 곱하기(승민) 승민 2016.08.27 1271
242 포인트 승민 2016.09.10 190
241 오른쪽으로돌려쓰기 선우 2016.10.29 143
240 대덕마고 승민 2016.10.29 162
239 10/29문자열 선우 2016.10.29 117
238 알파벳 배열2-1 승민 2016.10.29 191
237 테두리(승민) 승민 2016.11.12 151
236 테두리(승민) 승민 2016.11.12 165
235 dd 선우 2016.11.19 88
234 dd 승민 2016.11.19 128
233 졸업문제 선우 2016.11.19 301
232 ㅇㅇㅇ 선우 2016.11.19 122
231 주사위 굴리기 갓초딩 2017.03.25 1418
Board Pagination Prev 1 ... 9 10 11 12 13 14 15 16 17 18 ... 26 Next
/ 26