Triangeltal
문제
I en klass med 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 kommer sedan presentera för grupp , grupp för grupp , och grupp för grupp .
Något som krånglar till den här gruppindelningen är att eleverna har olika ambitionsnivå. Varje elev kräver att få hålla tal inför minst personer. Så om elev nummer exempelvis hamnar i grupp , så måste grupp ha minst medlemmar för att elev ska bli nöjd.
[이미지 1]
Bilden motsvarar första exemplet.
Du får givet de talen , 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 (), antalet elever i klassen.
Den andra raden innehåller heltal (), där är antalet elever den :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 bestående av tecknen , och . Tecknet på plats i denna sträng indikerar vilken grupp elev 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