W tradycyjnym Tetris istnieje 7 różnych cegieł tetromino , z których każda jest oznaczona literą podobną do kształtu.
#
# # #
# ## # # ### ## ##
# ## ## ## # ## ##
I O L J T Z S
Rozważ rozmieszczenie tych cegieł, które mogą tworzyć solidny prostokąt W × H, dla niektórych liczb całkowitych dodatnich W i H. Na przykład, używając 2 I, 1 L, 1 J, 2 T i 1 S, prostokąt 7 × 4 może być wykonane:
IIIITTT
LIIIITJ
LTTTSSJ
LLTSSJJ
Te same cegły można przestawiać (przesuwając i obracając, ale nie odwracając ) w inny wzór 7 × 4:
IJJTLLI
IJTTTLI
IJSSTLI
ISSTTTI
Teraz rozważ użycie prostokątnego bloku kodu zamiast pierwszego układu. Na przykład ten 7 × 4 bit Pythona 3, który wypisuje Tetris
na standardowe wyjście:
p=print
x='Tet'
y='ris'
p(x+y)#
Według pierwszego układu Tetris jego 7 „klocków” to ...
x '
int y ' ='r is
p=pr t p( ='Te )# x +y
W drugim układzie (jednym z wielu możliwych) są one niezrozumiałe jako kod:
r#)x(x=
p'r'=y'
='istpT
p+ytnie
Ale biorąc pod uwagę cegły osobno, może być możliwe ich prawidłowe złożenie. To jest podstawa wyzwania.
Wyzwanie
To wyzwanie dla gliniarzy i rabusiów . Istnieją dwie konkurujące role, Jumblers i Rebuilders .
Jumblery przesyłają odpowiedzi z blokami kodu, które zostały podzielone na klocki Tetris.
Rebuilderzy próbują odbudować te bloki w osobnym dedykowanym im pytaniu : Jumblers vs. Rebuilders: Coding with Tetris Bricks - Area for Rebuilder Answers .
Jumblers
Używając tylko drukowalnego ASCII (kody szesnastkowe od 20 do 7E) napisz program prostokątny W × H. Po uruchomieniu musi wypisać jedyne słowo Tetris
na standardowe wyjście (lub najbliższą alternatywę). Nie zamieszczaj tego kodu w odpowiedzi; nie podawaj W ani H.Podziel je na układ klocków Tetris jak na powyższym przykładzie i opublikuj je w swojej odpowiedzi. (Twój kod może zawierać spacje, ale ponieważ trudno je rozróżnić, najlepiej jest użyć innego znaku zamiast spacji i powiedzieć ludziom, czego użyłeś).
Im trudniej jest odbudować program, tym lepiej. Istnieje wiele sposobów na przestawienie cegieł kodowych w prostokąt, prawdopodobnie o różnych wymiarach. To, co robi kod, gdy działa w tych różnych aranżacjach, nie ma znaczenia, dopóki co najmniej jeden aranż jest drukowany Tetris
na standardowe wyjście.
Jedynym innym ograniczeniem jest to, że W * H będzie mniejsze niż 1025.
Jumblery powinny określić swój język programowania (i wersję).
Odbudowują
Twoim celem jest wzięcie klocków Jumblera i ułożenie ich z powrotem w ich oryginalnej kolejności, tak aby Tetris
było drukowane po uruchomieniu kodu. Jeśli znaleziony przez ciebie układ roboczy nie jest tym, o którym pomyślał Jumbler, to dla nich szkoda.
Pamiętaj, że tylko translacje i rotacje są dozwolone w przegrupowaniach, a nie dublowaniu.
Punktacja
Za każdym razem, gdy przesłanie jest przebudowywane, jest uważane za „pęknięte” i nie jest już uruchomione. Pierwszy Rebuilder, który odbudował zgłoszenie, otrzymuje za to kredyt. Jeśli odpowiedź nie zostanie zerwana przez 72 godziny, Jumbler powinien ujawnić rozwiązanie i odtąd będzie odporny na pękanie. Jumbler musi to zrobić, aby wygrać, ponieważ w przeciwnym razie nie będzie jasne, czy w ogóle istniało rozwiązanie.
Zwycięski Jumbler to nieskradziona odpowiedź z najmniejszym obszarem (W * H = 4 * liczba cegieł). W przypadku remisu wygrywa najwyższa głosowana odpowiedź. Odpowiedzią na to pytanie będzie zwycięski Jumbler.
Zwycięski Rebuilder to użytkownik, który łamie najwięcej zgłoszeń. W przypadku powiązań trafia do każdego, kto złamał najbardziej skumulowany obszar.
Notatki
- Nie możesz odbudowywać własnych zgłoszeń. (Ale w przeciwnym razie możesz przyjąć obie role).
- Odbudowujący nie mogą próbować złamać tej samej odpowiedzi więcej niż raz.
Tablica wyników
Posortowane od najstarszego zgłoszenia do najnowszego.
+--------------+-------------+------------------+---------+----------+----------------+-------------------------------------------+-------------------------------------------+
| Jumbler | Language | Area | Immune? | Rebuilt? | Rebuilder | Link | Solution Link |
+--------------+-------------+------------------+---------+----------+----------------+-------------------------------------------+-------------------------------------------+
| xnor | Python 3 | 212 | no | yes | foobar | https://codegolf.stackexchange.com/a/40142 | https://codegolf.stackexchange.com/a/40203 |
| xnor | Python 3 | 340 | no | yes | feersum | https://codegolf.stackexchange.com/a/40146 | https://codegolf.stackexchange.com/a/40189 |
| es1024 | C | 80 | no | yes | user23013 | https://codegolf.stackexchange.com/a/40155 | https://codegolf.stackexchange.com/a/40210 |
| Ethiraric | Brainfuck | 108 | yes | | | https://codegolf.stackexchange.com/a/40156 | |
| Qwertiy | JavaScript | 420 | yes | | | https://codegolf.stackexchange.com/a/40161 | |
| user23013 | Befunge | 360 | yes | | | https://codegolf.stackexchange.com/a/40163 | |
| user23013 | CJam | 80 | yes | | | https://codegolf.stackexchange.com/a/40171 | |
| Geobits | Java | 360 | yes | | | https://codegolf.stackexchange.com/a/40180 | |
| Dennis | CJam | 60 | yes | | | https://codegolf.stackexchange.com/a/40184 | |
| xnor | Python 3 | 160 | yes | | | https://codegolf.stackexchange.com/a/40192 | |
| COTO | C | 72 | yes | | | https://codegolf.stackexchange.com/a/40198 | |
| es1024 | C | 780 | yes | | | https://codegolf.stackexchange.com/a/40202 | |
| Gerli | Mathematica | 72 | no | yes | Martin Büttner | https://codegolf.stackexchange.com/a/40230 | https://codegolf.stackexchange.com/a/40242 |
| Hydrothermal | JavaScript | 80 | yes | | | https://codegolf.stackexchange.com/a/40235 | |
| Sam Yonnou | GolfScript | 48 (frontrunner) | yes | | | https://codegolf.stackexchange.com/a/40239 | |
| feersum | Matlab | 48 | | | | https://codegolf.stackexchange.com/a/40310 | |
| Beta Decay | Python 3 | 484 | | | | https://codegolf.stackexchange.com/a/40312 | |
| potato | Python 3 | 176 | | | | https://codegolf.stackexchange.com/a/40341 | |
+--------------+-------------+------------------+---------+----------+----------------+-------------------------------------------+-------------------------------------------+
(Dzięki http://www.sensefulsolutions.com/2010/10/format-text-as-table.html za formatowanie tabeli.)
Użytkownik COTO stworzył doskonałe narzędzie do gry klockami . Przekształciłem go w wygodny fragment:
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><script>function parseSpec(s){function first(){var e,t;t=S.findIndex(function(t){return(e=t.findIndex(function(e){return/\S/.test(e)}))!=-1});return t==-1?null:[e,t]}function at(e){var t=e[0],n=e[1];return n>=0&&n<S.length&&t>=0&&t<S[n].length?S[n][t]:" "}function wipe(e){var t=e[0],n=e[1];if(n>=0&&n<S.length&&t>=0&&t<S[n].length)S[n][t]=" "}var P,S=s.split("\n").map(function(e){return e.split("")});var oPats=$(".proto-tet [pat]").get().map(function(e){return{sPat:eval("["+$(e).attr("pat")+"]"),e:e,block:function(e){return[at(e)].concat(this.sPat.map(function(t){return at([e[0]+t[0],e[1]+t[1]])}))},wipe:function(e){this.sPat.forEach(function(e){return wipe([P[0]+e[0],P[1]+e[1]])})},match:function(e){return!/\s/.test(this.block(e).join(""))}}});window.oPats=oPats;while(P=first()){var oPat=oPats.find(function(e){return e.match(P)});if(!oPat){orphan(at(P));wipe(P);continue}createPiece(oPat.e,oPat.block(P));wipe(P);oPat.wipe(P)}}function createPiece(e,t){function r(e){var t=$(this).position();G.isIgnoreClick=false;G.eDrag=this;G.iOffsets=[e.clientX-t.left,e.clientY-t.top]}function i(){if(G.isIgnoreClick)return;var e=$(this);s($(".proto-tet ."+e.attr("rr")),function(e,t){return n[t-1]},e.css("left"),e.css("top"));e.remove()}function s(e,t,n,s){e.clone().html(e.html().replace(/@(\d)(\d)/g,t)).appendTo("body").on("mousedown",r).click(i).css({left:n,top:s})}var n=[];s($(e),function(e,r,i){return n[r-1]=t[i-1]},18+G.iSpawn%8*18*4+"px",18+~~(G.iSpawn/8)*18*4+"px");G.iSpawn++}function init(){$(document).on("mouseup",function(){return G.eDrag=null}).on("mousemove",function(e){if(G.eDrag){var t=$(G.eDrag),n=Math.round((e.clientX-G.iOffsets[0])/18)*18,r=Math.round((e.clientY-G.iOffsets[1])/18)*18,i=t.position();if(n!=i.left||r!=i.top)G.isIgnoreClick=true;t.css({left:n+"px",top:r+"px"})}})}function orphan(e){error("Spec character not a part of any block: '"+e+"'")}function error(e){$(".error").css("display","block").append("<div>"+e+"</div>")}function go(){$(init);$(function(){parseSpec($("#spec").val())});$("#spec").remove();$("#info").remove();$("#go").remove()}var G={eDrag:null,isIgnoreClick:true,iSpawn:0};Array.prototype.findIndex=function(e){for(var t=0;t<this.length;t++){if(e(this[t]))return t}return-1};Array.prototype.find=function(e){var t=this.findIndex(e);if(t==-1)return;else return this[t]}</script><style>.proto-tet, .spec{display: none;}.tet-I{color: darkgreen;}.tet-J{color: orangered;}.tet-L{color: navy;}.tet-T{color: darkred;}.tet-O{color: darkcyan;}.tet-S{color: darkviolet;}.tet-Z{color: darkorange;}body > .tet{position: absolute;cursor: move;-webkit-touch-callout: none;-webkit-user-select: none;-khtml-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;border-collapse: collapse;}.tet td{width: 18px;height: 18px;font: bold 14px "Courier New",monospace;text-align: center;vertical-align: middle;padding: 0;}.error{z-index: 1024;position: absolute;display: none;color: red;font-weight: bold;background-color: white;}textarea{font-family: "Courier New", Courier, monospace;}</style><div id='info'>Put code-bricks here and hit OK. Re-run the snippet to restart.<br>(You may need to replace spaces in code-bricks with some other character first.)</div><textarea id='spec' rows='16' cols='80'>ABCD a b Oo c oo d E h F efg hg GFE GH f H e I IJK J l L LK kji kl j i t OP p QR rs MN on ST q m W z XY zxw yx Y Z y w WXZ</textarea><br><button id='go' type='button' onclick='go()'>OK</button><div class="proto-tet"><table class="tet tet-I tet-I0" rr="tet-I1" pat="[1,0],[2,0],[3,0]"><tr><td>@11</td><td>@22</td><td>@33</td><td>@44</td></tr></table><table class="tet tet-I tet-I1" rr="tet-I2" pat="[0,1],[0,2],[0,3]"><tr><td>@11</td></tr><tr><td>@22</td></tr><tr><td>@33</td></tr><tr><td>@44</td></tr></table><table class="tet tet-I tet-I2" rr="tet-I3" ><tr><td>@40</td><td>@30</td><td>@20</td><td>@10</td></tr></table><table class="tet tet-I tet-I3" rr="tet-I0"><tr><td>@40</td></tr><tr><td>@30</td></tr><tr><td>@20</td></tr><tr><td>@10</td></tr></table><table class="tet tet-J tet-J0" rr="tet-J1" pat="[0,1],[-1,2],[0,2]"><tr><td></td><td>@11</td></tr><tr><td></td><td>@22</td></tr><tr><td>@33</td><td>@44</td></tr></table><table class="tet tet-J tet-J1" rr="tet-J2" pat="[0,1],[1,1],[2,1]"><tr><td>@31</td><td></td><td></td></tr><tr><td>@42</td><td>@23</td><td>@14</td></tr></table><table class="tet tet-J tet-J2" rr="tet-J3" pat="[1,0],[0,1],[0,2]"><tr><td>@41</td><td>@32</td></tr><tr><td>@23</td><td></td></tr><tr><td>@14</td><td></td></tr></table><table class="tet tet-J tet-J3" rr="tet-J0" pat="[1,0],[2,0],[2,1]"><tr><td>@11</td><td>@22</td><td>@43</td></tr><tr><td></td><td></td><td>@34</td></tr></table><table class="tet tet-O tet-O0" rr="tet-O1" pat="[1,0],[0,1],[1,1]"><tr><td>@11</td><td>@22</td></tr><tr><td>@33</td><td>@44</td></tr></table><table class="tet tet-O tet-O1" rr="tet-O2"><tr><td>@30</td><td>@10</td></tr><tr><td>@40</td><td>@20</td></tr></table><table class="tet tet-O tet-O2" rr="tet-O3"><tr><td>@40</td><td>@30</td></tr><tr><td>@20</td><td>@10</td></tr></table><table class="tet tet-O tet-O3" rr="tet-O0"><tr><td>@20</td><td>@40</td></tr><tr><td>@10</td><td>@30</td></tr></table><table class="tet tet-L tet-L0" rr="tet-L1" pat="[0,1],[0,2],[1,2]"><tr><td>@11</td><td></td></tr><tr><td>@22</td><td></td></tr><tr><td>@33</td><td>@44</td></tr></table><table class="tet tet-L tet-L1" rr="tet-L2" pat="[1,0],[2,0],[0,1]"><tr><td>@31</td><td>@22</td><td>@13</td></tr><tr><td>@44</td><td></td><td></td></tr></table><table class="tet tet-L tet-L2" rr="tet-L3" pat="[1,0],[1,1],[1,2]"><tr><td>@41</td><td>@32</td></tr><tr><td></td><td>@23</td></tr><tr><td></td><td>@14</td></tr></table><table class="tet tet-L tet-L3" rr="tet-L0" pat="[-2,1],[-1,1],[0,1]"><tr><td></td><td></td><td>@41</td></tr><tr><td>@12</td><td>@23</td><td>@34</td></tr></table><table class="tet tet-S tet-S0" rr="tet-S1" pat="[1,0],[-1,1],[0,1]"><tr><td></td><td>@21</td><td>@12</td></tr><tr><td>@43</td><td>@34</td><td></td></tr></table><table class="tet tet-S tet-S1" rr="tet-S2" pat="[0,1],[1,1],[1,2]"><tr><td>@41</td><td></td></tr><tr><td>@32</td><td>@23</td></tr><tr><td></td><td>@14</td></tr></table><table class="tet tet-S tet-S2" rr="tet-S3"><tr><td></td><td>@30</td><td>@40</td></tr><tr><td>@10</td><td>@20</td><td></td></tr></table><table class="tet tet-S tet-S3" rr="tet-S0"><tr><td>@10</td><td></td></tr><tr><td>@20</td><td>@30</td></tr><tr><td></td><td>@40</td></tr></table><table class="tet tet-Z tet-Z0" rr="tet-Z1" pat="[1,0],[1,1],[2,1]"><tr><td>@11</td><td>@22</td><td></td></tr><tr><td></td><td>@33</td><td>@44</td></tr></table><table class="tet tet-Z tet-Z1" rr="tet-Z2" pat="[-1,1],[0,1],[-1,2]"><tr><td></td><td>@11</td></tr><tr><td>@32</td><td>@23</td></tr><tr><td>@44</td><td></td></tr></table><table class="tet tet-Z tet-Z2" rr="tet-Z3"><tr><td>@40</td><td>@30</td><td></td></tr><tr><td></td><td>@20</td><td>@10</td></tr></table><table class="tet tet-Z tet-Z3" rr="tet-Z0"><tr><td></td><td>@40</td></tr><tr><td>@20</td><td>@30</td></tr><tr><td>@10</td><td></td></tr></table><table class="tet tet-T tet-T0" rr="tet-T1" pat="[1,0],[2,0],[1,1]"><tr><td>@11</td><td>@22</td><td>@33</td></tr><tr><td></td><td>@44</td><td></td></tr></table><table class="tet tet-T tet-T1" rr="tet-T2" pat="[-1,1],[0,1],[0,2]"><tr><td></td><td>@11</td></tr><tr><td>@42</td><td>@23</td></tr><tr><td></td><td>@34</td></tr></table><table class="tet tet-T tet-T2" rr="tet-T3" pat="[-1,1],[0,1],[1,1]"><tr><td></td><td>@41</td><td></td></tr><tr><td>@32</td><td>@23</td><td>@14</td></tr></table><table class="tet tet-T tet-T3" rr="tet-T0" pat="[0,1],[1,1],[0,2]"><tr><td>@31</td><td></td></tr><tr><td>@22</td><td>@43</td></tr><tr><td>@14</td><td></td></tr></table></div><div class="error"></div>
źródło
Odpowiedzi:
GolfScript 48
I
sztuk:O
sztuk:T
sztuk:J
sztuk:Rozwiązanie
źródło
Java: obszar 360
Wykonane z mieszanki wszystkich siedmiu rodzajów sztuk. Aby to ułatwić (?) Upewniłem się, że wszystkie elementy tego samego typu są obrócone w tej samej orientacji. Ponieważ Java ma części, których nie można wiele zmienić, zostawiłem te naprawdę oczywiste części jako proste I-bloki, aby je uruchomić.
Uwaga: Ponieważ Java ma kilka obowiązkowych spacji, zamieniłem je na podkreślenia (
_
) poniżej dla celów układu. Jest ich w sumie 11 i wszystkie powinny zostać przekonwertowane na spacje, aby uruchomić kod. W kodzie nie ma innych białych znaków, wszystkie poniżej służą wyłącznie do pozycjonowania.Tam są:
Baw się dobrze!
źródło
Brainfuck, obszar 108
Ten kod został złożony z 27 części I.
Nie wiem, czy istnieje jakikolwiek inny sposób niż brutalna siła, aby znaleźć odpowiedź. Jeśli tak, naprawdę chciałbym wiedzieć, jak to zrobić.
źródło
Obszar Python 3: 212 [Przebudowany]
Mój kod jest podzielony na następujące 53
I
elementy, które napisałem jeden w wierszu alfabetycznie.Baw się dobrze!
źródło
print('Tetris'* (3580048039607960824098110131314133014381502228523172479258529553116373838184169435643604632480050165153525653945598563157585840631264256539704571638903974876749009825073297156762481649%38941394))
%3894
?print('Tetris'* (358UNKNOWN94))
i ponieważ byłem całkiem pewien, że nie obróciłeś żadnych płytek, wszystko, co zrobiłem, to zbudowałem wszystkie możliwe kombinacje pozostałych płytek, połączyłem je razem i oceniłem, czy358UNKNOWN94
jest równy1
, a ja zastąpiłemUNKNOWN
permutacją . Więc nie użyłem,%3894
ponieważ najpierw znaleziono inną pasującą permutację;) Nie wiem, ile dokładnie to zajęło, ale zajęło to około 20 minut przy użyciu jednego rdzenia. Użyłem więc czegoś mniej systematycznego, po prostu brutalnie zastosowałem rozwiązanie;)JavaScript - obszar 80
Wydaje się, że wiele z tych odpowiedzi używa tylko wielu kawałków I, a może kawałka O lub dwóch, więc rzuciłem to razem z niektórymi bardziej interesującymi kształtami.
Każdy element jest oddzielony dwoma spacjami. Dwa znaki skrótu są w rzeczywistości spacjami w kodzie.
Baw się dobrze!
źródło
JavaScript, obszar 420
Tylko ja-bloki.
Nie użyto żadnych standardowych zaciemniaczy. Cały kod, w tym zaciemnianie i tworzenie tej posortowanej listy bloków, składa się z mniej niż 16 wierszy mojego własnego kodu.
Czas pokazać, jak powstał:
Jest to po prostu wywołanie
eval
z zaciemnionym'console.log("Tetris")'
argumentem, który ma 420 symboli długości. Jest podzielony na 4 linie po 105 symboli i odczytywany według kolumn i posortowany alfabetycznie.Zaciemnienie dla 10 cyfr jest zakodowane na stałe, dla innych symboli użyto pierwszych 10 symboli z 4 kombinacji przekazanych do
add
funkcji. Jeśli nie ma zaciemnienia dla jakiegoś symbolu, jest on przekazywany w niezmienionej postaci.źródło
C, powierzchnia 80
Wykonany z 12
I
sztuk i 8O
sztuk. Składnia C jest zawsze zabawna.I
elementy w określonej kolejności:O
sztuk:źródło
main(q){char c[]
={'/T','$"e','t'
,0162,'rIi>`:i',
'?#>s',q<q/**/};
return puts(c);}
CJam, 60 (15 O)
Rozwiązanie
źródło
Befunge, obszar 360
90
O
sztuk.Możesz spróbować tutaj .
źródło
Obszar Pythona 3: 340 [Przebudowany]
Wykonany z 85
I
elementów, podanych tutaj alfabetycznie po jednym w wierszu.Jako lista Python:
źródło
Obszar Pythona 3: 160
Po pęknięciu feersum próbowałem zaostrzyć kod, aby trudniej było uniknąć kryptograficznego mumbo-jumbo. Składa się z 40
I
elementów, wymienionych po jednym w rzędzie:Jako lista Python:
Zmieniono:
pow
użycie1
„sMartwię się jednak wieloma czynnikami tego obszaru.
źródło
C - Obszar 72
Bloki:
Ponieważ jedyne inne zgłoszenie C zostało złamane. ;)
Zgrabne 72 znaki. Czyste zaciemnianie. Żadnych trudnych do rozwiązania problemów NP lub ogromnych liczb całkowitych do uwzględnienia. Pożycza kilka sztuczek od jednego z wielkich. Spacje są reprezentowane za pomocą
.
s. W rozwiązaniu nie.
pojawiają się żadne rzeczywiste litery.Potrójnie sprawdziłem rozwiązanie, aby zapewnić ważność elementów.
źródło
CJam, obszar 80
20
O
sztuk.źródło
C - Obszar 780
Łącznie jest 195 sztuk. Nie użyto żadnych komentarzy. Nic szczególnie skomplikowanego.
Uwaga: wszystkie odwrotne ukośniki (
\
) należy zastąpić spacjami.95
I
sztuk:35
O
sztuk:18
L
sztuk:25
J
sztuk:10
T
sztuk:4
Z
sztuki:8
S
sztuk:Rozwiązanie
źródło
Wolfram, obszar 72
Wszędzie, gdzie zobaczysz myślnik (-), zamień go na spację
ja
jot
l
o
s
z
t
źródło
T
bloku powinny być odwrotnie. Udało mi się go odbudować .MATLAB, obszar 48
Niestety nie działa w Octave.
źródło
Python 3 176 Area
Nie używam podkreślników w tym programie, więc postanowiłem zastąpić wszystkie spacje podkreśleniami, aby zwiększyć czytelność. Upewnij się, że umieściłeś je z powrotem w spacji, jeśli nie złożysz ich razem.
I Bloki:
O Bloki:
Bloki L:
Bloki J:
Bloki T:
Bloki Z:
Bloki S:
źródło
Python 3
Obszar - 484
Miejsca zastąpione przez
%
. Istnieje kilka komentarzy używanych jako wypełnienie. Trochę powtórzenia kodu. Może być dość skomplikowane.121 Os
źródło