Perl 5 , Ruby , JavaScript (chrom), PHP , Python 2 , Python 3 , 1206 bajtów, wynik 6 6 /1206 = +38,6865671641791
q=1//2;s=+0;s|0;"/.__id__;#";_="""q=1//2;s=+0;s|0;"/.__id__;#";_={0}{1}{0};R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q={0}{2}{0};print(_.format(Q,_,q[0:-12]+R,"%"))""";R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q="""|;#<?ob_end_clean();
eval($_='"$t"?0?[$q=37 .chr+113 .chr+38 .chr,$p=(96 .chr+39 .chr)*4,$n=10 .chr,$s=39 .chr*12,$S=34 .chr*3]:eval("printf=console.log;c=String.fromCharCode;$q=c(96);$p=c(37,113,38,39).repeat(4);$n=c(10);$s=c(39).repeat(12);$S=c(34,34,34)"):[]?[$q=q(!g)^PA,$p=HARHARHARHAR^od2od2od2od2,$n=R^X,$s=bbbbbbbbbbbb^EEEEEEEEEEEE,$S=hhh^JJJ]:[$q=O^h,$p=str_repeat(RHa3^w9GS,4),$n=R^X,$s=str_repeat(b^E,12),$S=HHH^jjj];//#');printf($x='q=1//2;s=+0;s|0;"/.__id__;#";_=%7$sq=1//2;s=+0;s|0;"/.__id__;#";_={0}{1}{0};R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q={0}{2}{0};print(_.format(Q,_,q[0:-12]+R,"%8$s"))%7$s;R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q=%7$s|;#<?ob_end_clean();%5$seval($_=%3$s%1$s%3$s);printf($x=%3$s%2$s%3$s,$_,$x,$q,$p,$n,$s,$S,"%8$s",![]||([]+[])?$n:"");//#%4$s%6$s%7$s;print(_.format(Q,_,q[0:-12]+R,"%8$s"))%9$s',$_,$x,$q,$p,$n,$s,$S,"%",![]||([]+[])?$n:"");//#`q&%`q&%`q&%`q&%''''''''''''""";print(_.format(Q,_,q[0:-12]+R,"%"))
Sprawdź poprawność Perla, Ruby, PHP, Python 2 i Python 3 online!
Uwaga : uruchomienie powyższego programu w konsoli Inspector w Chrome (która wydaje się obsługiwać argumenty pozycyjne console.log) zwraca właściwy program.
Wyjaśnienie
Okazało się to o wiele dłużej, niż się spodziewałem, a moje życie też stało się trochę trudniejsze, więc prawdopodobnie będę go majstrować. Chciałbym również dodać więcej języków, ale muszę znaleźć coś, co nie $miałoby nic przeciwko sigil ...
Jest to dość dużo standardowy format Quine gdzie obliczenie środki do wykorzystania jest trochę inna dla każdego języka: w Ruby %q&jest stosowany, wykorzystuje PHP ', JavaScript (node.js) wykorzystuje `i Perl 5 wykorzystuje q(... ). Ponieważ zmieniają się tylko cudzysłowy, reszta programu jest nadal wykonywalna i poprawna składnia w każdym języku. Python 2 i 3 są owinięte wokół poprzedniego programu przy użyciu """Python 2 i '''Python 3.
Wynikowe programy Perl i Ruby nie są standardowymi quinesami, dodatkowe q/ %qs są dodawane przy każdej iteracji, ale pierwszy program zwraca poprawnie.
Wyniki są następujące:
- Perl 5:
eval($_=q&... q&);printf($x=q&... q&,... );//#'%`'%`'%`'%`''''''''''''"""...
- Ruby:
eval($_=%q&... %q&);printf($x=%q&... %q&,... );//#`'`'`'`'''''''''''''"""...
- JavaScript (Chrome):
eval($_=`... `);printf($x=`... `,... );//#%q&'%q&'%q&'%q&'''''''''''''"""...
- PHP:
eval($_='... ');printf($x='... ',... );//#`q&%`q&%`q&%`q&%''''''''''''"""...
- Python 2:
... _="""... """;... q="""...''''''''''''""";print(_.format(Q,_,q[0:-12]+R,"%"))
- Python 3:
... _='''... ''';... q='''...""""""""""""''';print(_.format(Q,_,q[0:-12]+R,"%"))
Dużo to przerabiałem, mam nadzieję, że nie przegapiłem tutaj żadnego klucza. Nadal mam spory sposób, aby znaleźć się gdzieś blisko wyniku Jo Kinga ...