ในแบบดั้งเดิมTetris , มี 7 ที่แตกต่างกันtetrominoอิฐแต่ละแทนด้วยตัวอักษรคล้ายกับรูปร่างของมัน
#
# # #
# ## # # ### ## ##
# ## ## ## # ## ##
I O L J T Z S
ลองพิจารณาการจัดเรียงของอิฐเหล่านี้ที่สามารถสร้างรูปสี่เหลี่ยมผืนผ้า W × H ที่เป็นของแข็งสำหรับจำนวนเต็มบวก W และ H บางตัวอย่างเช่นการใช้ 2 I, 1 L, 1 J, 1 J, 2 T's และ 1 S, สี่เหลี่ยมผืนผ้า 7 × 4 ทำ:
IIIITTT
LIIIITJ
LTTTSSJ
LLTSSJJ
อิฐเดียวกันสามารถจัดใหม่ (โดยการย้ายและหมุน แต่ไม่พลิก ) เป็นรูปแบบที่แตกต่างกัน 7 × 4:
IJJTLLI
IJTTTLI
IJSSTLI
ISSTTTI
ตอนนี้ให้พิจารณาใช้บล็อกสี่เหลี่ยมของรหัสแทนการจัดเรียงครั้งแรก ตัวอย่างเช่น Python 3 ขนาด 7 × 4 บิตนี้ซึ่งพิมพ์Tetris
ไปยัง stdout:
p=print
x='Tet'
y='ris'
p(x+y)#
ตาม Tetris แรกที่จัดเรียง "อิฐ" 7 ของมันคือ ...
x '
int y ' ='r is
p=pr t p( ='Te )# x +y
ในการจัดการอื่น ๆ (หนึ่งในหลาย ๆ ที่เป็นไปได้) พวกเขาไม่สามารถเข้าใจได้ว่าเป็นรหัส:
r#)x(x=
p'r'=y'
='istpT
p+ytnie
แต่หากแยกก้อนอิฐออกเป็นชิ้น ๆ มันอาจเป็นไปได้ที่จะรวมมันเข้าด้วยกันอย่างถูกต้อง นี่คือพื้นฐานของความท้าทาย
ท้าทาย
นี่เป็นความท้าทายของตำรวจและโจร มีสองบทบาทการแข่งขันที่มีJumblersและRebuilders
Jumblers ส่งคำตอบด้วยบล็อคของรหัสที่ถูกแบ่งย่อยเป็นอิฐ Tetris
Rebuilders พยายามที่จะสร้างบล็อกเหล่านี้ใหม่ในคำถามแยกต่างหากสำหรับพวกเขาโดยเฉพาะ: Jumblers vs Rebuilders: การเข้ารหัสด้วย Tetris Bricks - พื้นที่สำหรับคำตอบของผู้สร้างใหม่
Jumblers
การใช้เฉพาะASCII ที่พิมพ์ได้ (รหัสเลขฐานสิบหก 20 ถึง 7E) เขียนโปรแกรมรูปสี่เหลี่ยมผืนผ้า W × H เมื่อเรียกใช้จะต้องส่งออกคำเดียวTetris
ไปยัง stdout (หรือทางเลือกที่ใกล้เคียงที่สุด) อย่าโพสต์รหัสนี้ในคำตอบของคุณ; อย่าให้ W หรือ H เช่นกัน แยกมันออกเป็นการจัดเรียงของอิฐ Tetris เช่นตัวอย่างข้างต้นและโพสต์เหล่านี้ในคำตอบของคุณ (รหัสของคุณอาจมีช่องว่าง แต่เนื่องจากยากต่อการแยกจึงควรใช้อักขระอื่นแทนช่องว่างและบอกคนที่คุณใช้
ยิ่งสร้างโปรแกรมของคุณได้ดีขึ้น อาจมีหลายวิธีในการจัดเรียงรหัสอิฐของคุณใหม่ให้เป็นสี่เหลี่ยมผืนผ้า สิ่งที่รหัสทำเมื่อทำงานในการจัดเรียงที่แตกต่างกันเหล่านี้ไม่สำคัญตราบใดที่การจัดเรียงอย่างน้อยหนึ่งพิมพ์Tetris
ไปที่ stdout
ข้อ จำกัด อื่น ๆ เท่านั้นคือ W * H จะน้อยกว่า 1,025
Jumblers ควรระบุภาษาการเขียนโปรแกรม (และเวอร์ชั่น)
Rebuilders
เป้าหมายของคุณคือนำอิฐรหัสของ Jumbler มาใส่ในลำดับเดิมดังนั้นTetris
จะพิมพ์ออกมาเมื่อมีการเรียกใช้รหัส หากการจัดการการทำงานที่คุณพบไม่ใช่ Jumbler ที่มีอยู่ในใจที่ไม่ดีสำหรับพวกเขา
โปรดจำไว้ว่าอนุญาตเฉพาะการแปลและการหมุนเท่านั้นในการจัดเรียงใหม่ไม่ใช่การสะท้อน
เกณฑ์การให้คะแนน
ทุกครั้งที่มีการสร้างการส่งใหม่จะถือว่า "แตก" และจะไม่ทำงานอีกต่อไป ตัวสร้างใหม่แรกที่สร้างการส่งใหม่ได้รับเครดิตสำหรับมัน หากคำตอบไม่ได้ถูกแยกออกเป็นเวลา 72 ชั่วโมง Jumbler ควรเปิดเผยวิธีการแก้ปัญหาและต่อจากนี้ไปจะมีภูมิคุ้มกันจากการถูกแคร็ก Jumbler จะต้องทำสิ่งนี้เพื่อให้ชนะเพราะไม่เช่นนั้นมันจะไม่ชัดเจนหากมีวิธีแก้ไขด้วย
Jumbler ที่ชนะคือคำตอบที่ไม่ได้แยกด้วยพื้นที่ที่เล็กที่สุด (W * H = 4 * จำนวนอิฐ) ในกรณีที่ผูกคำตอบที่ได้คะแนนสูงสุดจะเป็นฝ่ายชนะ คำตอบที่ได้รับการยอมรับสำหรับคำถามนี้จะเป็น Jumbler ที่ชนะ
ผู้สร้างใหม่ที่ชนะนั้นคือผู้ใช้ที่ถอดรหัสสิ่งที่ส่งมามากที่สุด ในกรณีของความสัมพันธ์มันจะไปที่ใครก็ตามที่แตกพื้นที่สะสมมากที่สุด
หมายเหตุ
- คุณไม่สามารถสร้างผลงานที่ส่งมาใหม่ของคุณเอง (แต่มิฉะนั้นคุณอาจรับบททั้งสองนี้)
- ผู้สร้างใหม่อาจไม่พยายามถอดรหัสคำตอบเดียวกันมากกว่าหนึ่งครั้ง
ป้ายบอกคะแนน
จัดเรียงจากการส่งที่เก่าแก่ที่สุดไปยังใหม่ที่สุด
+--------------+-------------+------------------+---------+----------+----------------+-------------------------------------------+-------------------------------------------+
| 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 | |
+--------------+-------------+------------------+---------+----------+----------------+-------------------------------------------+-------------------------------------------+
(ขอบคุณhttp://www.sensefulsolutions.com/2010/10/format-text-as-table.htmlสำหรับการจัดรูปแบบตาราง)
ผู้ใช้ COTOทำเครื่องมือที่ยอดเยี่ยมสำหรับการเล่นกับรหัส - อิฐ ฉันเปลี่ยนเป็นข้อมูลโค้ดที่สะดวก:
<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>