Triangeltal | 프로그래밍의 벗 PivotOJ
PivotOJ

Triangeltal

시간 제한: 5000ms메모리 제한: 1024MB출처: Programmeringsolympiaden 2022 — finalBOJ 26880
이 문제는 본문 이미지 일부가 표시되지 않습니다. 텍스트만으로 풀이가 어려울 수 있습니다.

문제

I en klass med NN elever har det blivit dags för det obligatoriska momentet att hålla tal. De flesta av eleverna ser fram emot att hålla tal väldigt mycket, och kan knappt vänta på sin tur. Men först måste de delas in i tre grupper. Alla i grupp 11 kommer sedan presentera för grupp 22, grupp 22 för grupp 33, och grupp 33 för grupp 11.

Något som krånglar till den här gruppindelningen är att eleverna har olika ambitionsnivå. Varje elev ii kräver att få hålla tal inför minst AiA_i personer. Så om elev nummer ii exempelvis hamnar i grupp 11, så måste grupp 22 ha minst AiA_i medlemmar för att elev ii ska bli nöjd.

[이미지 1]

Bilden motsvarar första exemplet.

Du får givet de NN talen AiA_i, och din uppgift är att avgöra om det finns ett sätt att dela in eleverna i tre grupper så att alla blir nöjda, och hitta i så fall en giltig indelning.

입력

Den första raden innehåller ett heltal NN (3N51053 \leq N \leq 5 \cdot 10^5), antalet elever i klassen.

Den andra raden innehåller NN heltal AiA_i (1AiN1 \leq A_i \leq N), där AiA_i är antalet elever den ii:te eleven minst vill hålla ett tal inför.

출력

Om det inte finns en giltig indelning, skriv ut en enda rad med strängen "NO".

Om det finns en giltig indelning, skriv först ut en rad med strängen "YES". Skriv därefter ut en rad med en sträng SS bestående av tecknen 11, 22 och 33. Tecknet på plats ii i denna sträng indikerar vilken grupp elev ii hamnade i. Om det finns flera lösningar kan du skriva ut vilken som helst.

예제

예제 1

입력
10
1 3 1 3 3 2 4 1 5 2
출력
YES
3313332121

예제 2

입력
3
1 2 2
출력
NO
이 문제는 채점 준비 중입니다. 테스트 데이터가 확보되면 제출이 가능합니다.