Korupcija | 프로그래밍의 벗 PivotOJ
PivotOJ

Korupcija

시간 제한: 1000ms메모리 제한: 2048MB출처: CHC 2025 Croatian Olympiad in InformaticsBOJ 34570

문제

... Korupcija svima, a ne samo njima. Ja nudim korupciju, koruptivni red, rad i rast. Sve što vam ovi majstori ponude, ja nudim duplo. Predlažem i osmi padež: Kome? Koliko? ...

Mali Mirko bio je očaran govorom stričeka s televizije. Bio je uvjeren kako je razumio poruku: morao je korumpirati bitove svojih binarnih brojeva.

Mirko promatra brojeve 0, 1, \dots , 2^N &minus; 1 (kao binarne brojeve s NN binarnih znamenki). Vođen željom za korupcijom, Mirko će izabrati dva broja XX i YY (0 &le; X, Y < 2^N) koja se razlikuju u točno jednom bitu. Mirko će tada prebrisati taj bit znakom “?” u oba broja XX i YY, čime je postigao korupciju: brojevi XX i YY više se ne mogu razlikovati. Mirko će ponavljati ovaj postupak s preostalim brojevima, dok na kraju ne dobije ukupno 2^N&minus;1 parova brojeva koji se ne mogu razlikovati. Dakle, svaki broj između 00 i 2^N &minus; 1 član je točno jednog para i dva broja mogu biti u paru isključivo ako se razlikuju u točno jednom bitu (binarnoj znamenci).

Radi većeg izazova, Mirko je odlučio da želi imati točno ai parova kojima znak “?” stoji na mjestu i-tog bita, za i = 0, 1, \dots , N &minus; 1. Pri tome, bitove brojimo od manje značajnih do više značajnih, pa tako ii-ti bit odgovara vrijednosti 2i2^i. Pomozite Mirku te napravite odabir parova koji zadovoljava tražene uvjete, ili odredite kako takav odabir ne postoji.

입력

U prvom je retku prirodan broj NN iz teksta zadatka.

U drugom je retku niz od NN nenegativnih cijelih brojeva aia_i, za i = 0, \dots , N &minus; 1, pri čemu aia_i predstavlja traženi broj parova koji se razlikuju u ii-tom bitu. Zbroj tih brojeva iznosi točno 2^N&minus;1.

출력

Ukoliko nije moguće napraviti odabir parova koji zadovoljava uvjete zadatka, u jedini redak ispišite -1.

Inače, ispišite 2^N&minus;1 redaka. U svaki redak ispišite dva razmakom odvojena broja XX i YY koji predstavljaju odabrani par. Parove možete ispisati u bilo kojem redoslijedu.

Ukoliko postoji više rješenja, ispišite bilo koje.

예제

예제 1

입력
2
2 0
출력
0 1
2 3

예제 2

입력
2
1 1
출력
-1

예제 3

입력
3
2 0 2
출력
0 1
2 6
3 7
4 5
코드를 제출하려면 로그인하세요.