조회 수 508 추천 수 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 743
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1500
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2845
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11230
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5168
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8997
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19440
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38320
130 정올 반복제어문3 형성평가1 정승준 2018.03.03 157
129 정올 반복제어문3 형성평가1 정승준 2019.02.02 366
128 정올 반복제어문3 형성평가2 정승준 2019.02.02 243
127 정올 반복제어문3 형성평가2 정승준 2018.03.10 152
126 정올 반복제어문3 형성평가2 정승준 2018.08.25 104
125 정올 반복제어문3 형성평가3 정승준 2019.02.02 282
124 정올 반복제어문3 형성평가3 정승준 2018.03.10 187
123 정올 반복제어문3 형성평가3 정승준 2018.08.25 106
122 정올 반복제어문3 형성평가4 정승준 2019.02.02 1114
121 정올 반복제어문3 형성평가4 정승준 2018.03.10 271
120 정올 반복제어문3 형성평가4 정승준 2018.08.25 80
119 정올 반복제어문3 형성평가5 정승준 2018.08.25 130
118 정올 반복제어문3 형성평가5(반대) 정승준 2018.08.25 69
117 정올 반복제어문3 형성평가6 정승준 2018.08.25 81
116 정올 반복제어문3 형성평가6 정승준 2018.03.17 175
115 정올 반복제어문3 형성평가6(비슷 1) 정승준 2018.08.25 83
114 정올 반복제어문3 형성평가6(비슷 2) 정승준 2018.08.25 70
113 정올 반복제어문3 형성평가7 정승준 2018.08.25 107
112 정올 반복제어문3 형성평가7 정승준 2018.03.17 197
111 정올 반복제어문3 형성평가7(반대) 정승준 2018.08.25 69
Board Pagination Prev 1 ... 15 16 17 18 19 20 21 22 23 24 ... 26 Next
/ 26