조회 수 513 추천 수 0 댓글 0

#include <stdio.h>

int check[100000]={0}; //지연수=불가능 -1=위치
int height[100000]={0};
int num[100000]={0};
int answer[100000]={0};

void line_height(int n); //키가 작은 순서대로 정렬
void line_people(int n); //사람들의 순서
//int where_num(int n, int a); //그 사람의 위치
//void check_no(int n); //위치가 정해진 키는 더이상 다른 위치에 올수 없으므로 불가능
//void pr(int n);
int main(void)
{
	int n, i;

	//입력 시작
	scanf(" %d", &n); //전체 사람의 수

	for(i=0; i<n; i++)
	{
		scanf(" %d", &height[i]); //사람들의 키
	}
	for(i=0; i<n; i++)
	{
		scanf(" %d", &num[i]); //자가 앞에 있는 사람들 중에서 자기보다 키가 작거나 같은 사람들의 수
	}
	//입력 끝

	line_height(n); //키가 작은 순서대로 정렬
	line_people(n);

	//정답 출력
	for(i=0; i<n; i++)
	{
		printf("%d\n", answer[i]);
	}

	return 0;
}
void line_height(int n)
{
	int i, j, temp, min;

	for(i=0; i<(n-1); i++)
	{
		min=i;
		for(j=i+1; j<n; j++)
		{
			if(height[j]<height[min])
			{
				min=j;
			}
		}
		if(min!=i)
		{
			temp=height[i];
			height[i]=height[min];
			height[min]=temp;
		}
	}
}
void line_people(int n)
{
	int i, j, w, c, cnt=1;

	for(i=n-1; i>=0; i--)
	{
		if(i!=0)
		{
			c=0;
			for(j=0; c<num[i]; j++)
			{
				if(check[j]!=-1)
				{
					check[j]=cnt; //작은 순서대로 num[i]개 만큼 불가능
					c++;
				}
			}
			c=0;
			for(j=n-1; c<(i-num[i]); j--)
			{
				if(check[j]!=-1)
				{
					check[j]=cnt; //큰 순서대로 (i-num[i])개 만큼 불가능 
					c++;
				}
			}
		}

		for(j=0; j<n; j++)
		{
			if(check[j]!=cnt && check[j]!=-1) //불가능 하지 않은 위치 
			{
				w=j;
				answer[i]=height[w];
				check[w]=-1;
				break;
			}
		}

		//pr(n);
		//check_no(n);
		//pr(n);
		//printf("\n");
		cnt++;
	}
}
/*int where_num(int n, int a)
{
	int i;

	for(i=0; i<n; i++)
	{
		if(check[i]!=a && check[i]!=-1) 
			return i;
	}
}*/
/*void check_no(int n)
{
	int i;

	for(i=0; i<n; i++)
	{
		if(check[i]==1)
		{
			check[i]=0;
		}
	}
}*/
/*void pr(int n)
{
	int i;

	for(i=0; i<n; i++)
	{
		printf("%d ", check[i]);
	}
	printf("\n");
}*/
//뒤에서부터 배열
//만약 작은 수가 4개라면  작은 순대로 4개 제외, 큰 순서재로 전체-4개 제외 



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 299
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1079
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2397
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10332
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4723
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8293
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 18960
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 37862
130 숫자두개 입력하고 큰거 작은거 구분하고 작은숫자부터 큰숫자까지 곱하기(승민) 승민 2016.03.19 222
129 숫자3개 연속 더하기 승민 2016.06.18 400
128 숫자 배열 삼각형 4가지 숙제 killerjack 2014.04.26 3603
127 숫자 3개 입력후 더할수잇는수 다더한 과정(승민) 승민 2016.08.13 133
126 숙제 함수1 형성평가5(승민) 승민 2016.07.16 136
125 숙제 달팽이배열 killerjack 2014.05.17 2012
124 숙제 file 박윤택 2013.12.21 1926
123 숙제 강호승 2013.08.17 2377
122 숙제 양태관 2013.06.22 2318
121 세자리수 곱해서 각자리수 곱하기(승민) 승민 2016.08.27 1258
120 세균전 복습 이번엔 내머리가 좀 많이 들어갓음 z키 기능 추가하고 복사 또는 이동 만들어야한다 killerjack 2014.07.05 658
119 세균전 복사하기 만들어야함 killerjack 2014.06.07 1101
118 세개의 정수로 연산 결과 출력 양태관 2013.06.22 3209
117 세개의 실수를 받아 큰수는 올림 작은수는 버림 남은수는 반올림하기 선우 2016.07.02 185
116 세 개 정수중 최댓값 최솟값 함수이용해서 구하기 killerjack 2014.02.15 251491
115 섭씨를 화씨로 화씨를 섭씨로 killerjack 2014.02.15 3332
114 섭씨 화씨 뭐고를지 선택후 계산(승민) 승민 2016.06.11 537
113 삼각형 넓이구하기.(승민) 승민 2016.03.05 987
112 사이정수 갯수 구하기 테스트 버전 좋은아빠되기 2014.08.02 531
111 분수쇼 (승민) 승민 2016.07.23 133
Board Pagination Prev 1 ... 15 16 17 18 19 20 21 22 23 24 ... 26 Next
/ 26