ตัวต่อจิ๊กซอว์ ASCII


27

นี่คือตัวต่อ3x3ASCII:

 _____ _____ _____
|    _|     |_    |
|   (_   _   _)   |
|_   _|_( )_|_   _|
| (_) |_   _| (_) |
|  _   _) (_   _  |
|_( )_|_   _|_( )_|
|    _| (_) |_    |
|   (_       _)   |
|_____|_____|_____|

นี่คือ3x3จิ๊กซอว์ ASCII:

 _____ _____ _____
|     |_   _|     |
|  _   _) (_   _  |
|_( )_|_   _|_( )_|
|    _| (_) |_    |
|   (_   _   _)   |
|_   _|_( )_|_   _|
| (_) |_   _| (_) |
|      _) (_      |
|_____|_____|_____|

แต่ละบรรทัดในตัวต่อจิ๊กซอว์ ASCII (ไม่รวมกล่องขอบคือชิ้นส่วนที่แท้จริงที่ขอบ) ประกอบด้วยรูปแบบดังต่อไปนี้:

   _           _           _
 _( )_ _   _ _( )_ _   _ _( )_
|_   _| (_) |_   _| (_) |_   _|
 _) (_   _   _) (_   _   _) (_
|_   _|_( )_|_   _|_( )_|_   _| ...
  (_)         (_)         (_)

รับ 2 จำนวนเต็มHและWสถานที่ที่Hมีความสูง (จำนวนแนวตั้ง) และWเป็นความกว้าง (จำนวนแนวนอน) และHและWมีการ>1ส่งออกตัวต่อHxWจิ๊กซอว์ ASCII ที่เป็นไปได้

ตัวอย่าง

กรณีทดสอบ 1

การป้อนข้อมูล: 2, 4

เอาท์พุท:

 _____ _____ _____ _____
|     |_   _|     |_    |
|  _   _) (_   _   _)   |
|_( )_|_   _|_( )_|_   _|
|    _| (_) |_   _| (_) |
|   (_       _) (_      |
|_____|_____|_____|_____|

กรณีทดสอบ 2

การป้อนข้อมูล: 4, 4

เอาท์พุท:

 _____ _____ _____ _____
|     |_   _|     |_    |
|  _   _) (_   _   _)   |
|_( )_|_   _|_( )_|_   _|
|    _| (_) |_   _| (_) |
|   (_   _   _) (_   _  |
|_   _|_( )_|_   _|_( )_|
| (_) |_   _| (_) |_    |
|  _   _) (_   _   _)   |
|_( )_|_   _|_( )_|_   _|
|    _| (_) |_   _| (_) |
|   (_       _) (_      |
|_____|_____|_____|_____|

กรณีทดสอบ 3

การป้อนข้อมูล: 3, 5

เอาท์พุท:

 _____ _____ _____ _____ _____
|     |_   _|     |_   _|     |
|  _   _) (_   _   _) (_   _  |
|_( )_|_   _|_( )_|_   _|_( )_|
|    _| (_) |_   _| (_) |_    |
|   (_   _   _) (_   _   _)   |
|_   _|_( )_|_   _|_( )_|_   _|
| (_) |_   _| (_) |_   _| (_) |
|      _) (_       _) (_      |
|_____|_____|_____|_____|_____|

กรณีทดสอบ 4

การป้อนข้อมูล: 2, 2

เอาท์พุท:

 _____ _____
|    _|     |
|   (_   _  |
|_   _|_( )_|
| (_) |_    |
|      _)   |
|_____|_____|

ชี้แจง

  • ความสูงและความกว้างของแต่ละชิ้นส่วนจิ๊กซอร์ไม่ควรถูกปรับขึ้นหรือลง
  • ด้วยHและWเป็นมากกว่าหนึ่งมิติที่เล็กที่สุดที่เป็นไปได้คือ2x2(ดู IO 4)
  • คุณสามารถมีโปรแกรมหรือฟังก์ชั่นเต็มรูปแบบ
  • อินพุตจะเป็น 2 บรรทัดด้วยHในวันที่ 1 และWวันที่ 2 หากคุณใช้ฟังก์ชั่นคุณสามารถมีไว้ในพารามิเตอร์
  • ส่งออกไปยัง stdout (หรือสิ่งที่คล้ายกัน)
  • นี่คือ code-golf ดังนั้นคำตอบที่สั้นที่สุดในจำนวนไบต์ชนะ

แท็บของชิ้นส่วนต้องอยู่ในทิศทางสลับกันหรือไม่
Zgarb

ฉันควรจะสุ่มเอาท์พุทหรือฉันสามารถส่งต่อจิ๊กซอว์เดียวได้ทุกครั้ง หากสุ่มเลือกตัวต่อทั้งหมดควรมีรูปแบบเหมือนกันหรือไม่
user48538

@Zgarb ใช่ฉันแก้ไขในรูปแบบพื้นฐานแต่ละบรรทัดในจิ๊กซอว์ต่อไปนี้
Bobas_Pett

@ zyabin101 คุณเพียงแค่ต้องการส่งออก "จิ๊กซอว์ ASCII" ที่เป็นไปได้ดังนั้นเพียง 1 เอาต์พุตสำหรับ 1 อินพุต
Bobas_Pett

1
ความพยายามครั้งแรกดูเหมือนว่ามันจะจบลงที่ประมาณเมกะไบต์ เป็นคำถามที่ดี
ElPedro

คำตอบ:


6

JavaScript (ES6) 272 277 271

แก้ไขการแก้ไขข้อบกพร่อง

แก้ไข 2บันทึก 6 ไบต์ thx @ L.Serné

แก้ไขการแก้ไขข้อบกพร่อง3ครั้งอีกครั้ง

(w,h,z=(s,q=3,i=h)=>'|  '.slice(0,q)+s.repeat(w).substr(i%2*6+q,w*6-q-~-q)+`  |
`.slice(~q))=>eval("t=z(' _____',0,0)+z('|_   _|     ',2,--h)+z(b=' _) (_   _  ')+z(c='|_   _|_( )_',0);for(a='|_   _| (_) ';--h;)t+=z(a,2)+z(b)+z(c,0)")+z(a,2)+z(' _) (_      ')+z('|_____',1)

น้อย golfed

(w,h,
  z=(s,q=3,i=h)=>'|  '.slice(0,q)+s.repeat(w).substr(i%2*6+q,w*6-q-~-q)+'  |\n'.slice(~q),
  a='|_   _| (_) ',
  b=' _) (_   _  ',
  c='|_   _|_( )_',
  t=z(' _____',0,0)+z('|_   _|     ',2,--h)+z(b)+z(c,0)
)=>{
  for(;--h;)
    t+=z(a,2)+z(b)+z(c,0);
  return t+z(a,2)+z(' _) (_      ')+z('|_____',1)
}

ทดสอบ

F=
(w,h,z=(s,q=3,i=h)=>'|  '.slice(0,q)+s.repeat(w).substr(i%2*6+q,w*6-q-~-q)+`  |
`.slice(~q))=>eval("t=z(' _____',0,0)+z('|_   _|     ',2,--h)+z(b=' _) (_   _  ')+z(c='|_   _|_( )_',0);for(a='|_   _| (_) ';--h;)t+=z(a,2)+z(b)+z(c,0)")+z(a,2)+z(' _) (_      ')+z('|_____',1)

function update() {
  var w=+W.value,h=+H.value
  O.textContent=F(w,h)
}

update()
W<input id=W value=2 oninput='update()' type=number min=2>
H<input id=H value=2 oninput='update()' type=number min=2>
<pre id=O></pre>


ดีมาก! รุ่น golfed ทำให้ฉันมีปัญหา แต่: Nx2 ไม่ทำงาน (เช่น 3x2 ให้ผลไม่ได้กำหนด | | ( ) | _ | | (_ _) | | _____ | _____ | _____ | และส่งผลความสูงคี่ในมุมบนขวา ชิ้นส่วนไม่มีเส้นขอบด้านบนดูเหมือนว่าบางสิ่งได้หายไปในสนามกอล์ฟแก้ไข: ข้อผิดพลาด "ความสูงคี่" จากผลของทั้งรหัสที่เล่นกอล์ฟและไม่เล่นกอล์ฟ
Bence Joful

@BentJoful ทดสอบไม่เพียงพอหลังจากการเล่นกอล์ฟครั้งสุดท้าย ตอนนี้ได้รับการแก้ไข
edc65

คุณสามารถย้ายการประกาศของอาร์กิวเมนต์ล่าสุด (t) และอาร์กิวเมนต์ที่สี่ (a) ไปยัง for loop (และเลื่อนการประกาศของ b และ c ภายในการประกาศของ t ดังนี้: for(t=z(' _____',0,0)+z('|_ _| ',2,--h)+z(b=' _) (_ _ ')+z(c='|_ _|_( )_',0);--h;a='|_ _| (_) ')สิ่งนี้ช่วยประหยัด 4 คอมมาดังนั้นคุณจึงจบลงด้วย เพียง 273 ตัวอักษรแก้ไข: ตัวอย่างการทดสอบยังคงบั๊ก ...
ลูกา

@ L.Sernéบั๊กอย่างไร? คุณไม่สามารถใส่t=...ข้างในสำหรับมันล้มเหลวสำหรับ h == 2 มันเป็นจุดบกพร่องที่ฉันได้แก้ไขในวันนี้
edc65

1
np ฉันเล่นไปพร้อมกับรหัสของคุณและสาเหตุของการundefinedประกาศออกมาaในส่วนสุดท้ายของforลูป ฉันเปลี่ยนรหัสเล็กน้อยและจบลงด้วยสิ่งนี้ คุณควรจะสามารถรวมกับ eval สำหรับการบันทึก 2B อื่น (w,h,z=(s,q=3,i=h)=>'| '.slice(0,q)+s.repeat(w).substr(i%2*6+q,w*6-2*q+1)+' |\n'.slice(~q),a='|_ _| (_) ')=>{for(t=z(' _____',0,0)+z('|_ _| ',2,--h)+z(b=' _) (_ _ ')+z(c='|_ _|_( )_',0);--h;)t+=z(a,2)+z(b)+z(c,0);return t+z(a,2)+z(' _) (_ ')+z('|_____',1)}(276 B)
ลุค

5

Python 513 ไบต์

def r(m,n):
 r=3*m
 c=6*n
 l=3-(n%2)*3
 z=[1,2,3,4,5,0]
 p=zip
 return"\n".join("".join(" |_()"[[[((j%6,i%3)in[(1,0),(5,0)])*2or((j%6,i%3)in[(0,1),(0,0)])or((j%4,i%6)in[(1,1),(1,2),(3,4),(3,5)])*2or((i%6,j%12)in p(z,[10,2,10,4,8,4]))*4or((i%6,j%12)in p(z,[8,4,8,2,10,2]))*3,1,0][j in[0,c]or((j,i%6)in p([1,1,2,2],[1,2]*2)+p([c-1,c-1,c-2,c-2],[1+l,2+l]*2)or(i,j%12)in[(1,8),(1,9),(1,10),(2,8),(2,9),(2,10),(r-1,9)]or(i,j%12)==(r-1,3+6*(m%2)))*2],2*(j%6>0)or i>0][i in[0,r]]]for j in range(c+1))for i in range(r+1))

บางทีการออกกำลังกายในความงงงวยมากกว่าในการเล่นกอล์ฟสิ่งนี้ทำงานโดยการตัดสินใจว่าอักขระแต่ละตัว(x,y)ประสานงานไปที่ใดแทนที่จะสร้างแต่ละรูปแบบด้วยสายอักขระ ดูเหมือนจะไม่ดี

char_codes = " |_()"
def base(row, col):
    if col % 6 in [5] and row % 3 in [0, 2]:
        return 1
    if col % 6 in [0, 4] and row % 3 in [2]:
        return 2
    return 0

def underscores(row, col):
    if col % 4 in [0] and row % 6 in [0, 1] or col % 4 in [2] and row % 6 in [3, 4]:
        return 2
    return 0

def parentheses(row, col):
    if (row % 6, col % 12) in [(0, 9), (1, 1), (2, 9), (3, 3), (4, 7), (5, 3)]:
        return 4
    if (row % 6, col % 12) in [(0, 7), (1, 3), (2, 7), (3, 1), (4, 9), (5, 1)]:
        return 3
    return 0

def value(row, col):
    return base(row, col) + underscores(row, col) + parentheses(row, col)

def new_value(last_row, last_col, row, column):
    if row in [0, last_row]:
        return 2*(column % 6 > 0) or row>0
    if column in [0, last_col]:
        return 1
    if column in [1,2] and row % 6 in [1, 2]:
        return 0
    if column in [last_col - 1, last_col - 2] and row % 6 in [[4,5],[1,2]][last_col%12>0]:
        return 0
    if row in [1, 2] and column % 12 in [8,9,10]:
        return 0
    if row == last_row - 1 and column % 12 == 9:
        return 0
    return value(row - 1, column - 1)

def puzzle(rows, cols):
    last_row = rows * 3
    last_col = cols * 6
    return "\n".join("".join(new_value(last_row, last_col, row, col) for col in range(last_col + 1)) for row in range(last_row + 1))

รูปแบบของตัวเองดูเหมือน

เราสามารถเห็นสิ่งนี้เป็นตารางการค้นหาจากจำนวนเต็มกับคอลัมน์นำ mod 6 และแถว mod 3

 012345
0     |
1
2_   _|

 0123
0_
1_
2
3  _
4  _
5

 0123456789AB
0       ( )
1 ) (
2       ( )
3 ( )
4       ) (
5 ( )

กลยุทธ์ของการรวมรูปแบบที่แตกต่างกันนี้ไม่ได้ผลสำหรับฉันที่นี่เพราะการแสดงพวกเขาค่อนข้างยุ่งยาก (แม้ว่าฉันคิดว่าฉันสามารถเล่นกอล์ฟได้มากกว่านี้) และเนื่องจากเคสขอบใช้ตัวอักษรจำนวนมากเพื่อแก้ไข ฉันกำลังทำสิ่งนี้ไม่ว่าจะเป็นเพราะใช้เวลาสักครู่และอาจเป็นที่สนใจ


1
คุณสามารถบันทึกได้ 7 ไบต์โดยใส่ทุกอย่างใน 1 บรรทัดคั่นด้วยเครื่องหมายอัฒภาค
Blue

@Blue ขอบคุณเพื่อนมานานแล้วตั้งแต่กอล์ฟครั้งสุดท้ายของฉันและฉันลืมเทคนิคบางอย่าง
walpen

2

Mathematica, 384 ไบต์

(m=#~Mod~2&;a=#~Array~Y&;s=(h="   _  ")[o="|_( )_",z="|_   _",w=" _) (_",z,p="| (_) "];l="|  _  "[o,"|    _",u="|   (_",z,p];r=h[o,q="|_    ",t=" _)   ",z,p];{X,Y}=#;a[" _____"&]<>" \n"<>Join[{a[If[#<Y,z,q]["|     "][[m@#]]&]},Table[Which[y<2,l,y<Y,s,0<1,r][[Mod[x+3y,6]]],{x,3,3X-1},{y,1,Y}],{a[If[#<2,"|     "[u],"      "[If[#<Y,w,t]]][[m[X+#]]]&],a["|_____"&]}]~Riffle~"|\n"<>"|")&

ฟังก์ชั่นที่ไม่ได้ตั้งชื่อใช้จำนวนคู่สั่งซื้อเป็นอาร์กิวเมนต์ของมันและส่งกลับสตริงที่มีการขึ้นบรรทัดใหม่ที่เหมาะสม ด้วยการเว้นวรรคและการขึ้นบรรทัดใหม่:

(m = Mod[#1, 2] &; a = Array[#1, Y] &; 
 s = (h = "   _  ")[o = "|_( )_", z = "|_   _", w = " _) (_", z, p = "| (_) "];
 l = "|  _  "[o, "|    _", u = "|   (_", z, p]; 
 r = h[o, q = "|_    ", t = " _)   ", z, p];
 {X, Y} = #1; 
 a[" _____" &] <> " \n" <>
 Riffle[
   Join[
     {a[If[#1 < Y, z, q]["|     "][[m[#1]]] &]}, 
     Table[
       Which[y < 2, l, y < Y, s, 0 < 1, r][[Mod[x + 3 y, 6]]],
       {x, 3, 3 X - 1}, {y, 1, Y}
     ],
     {a[If[#1 < 2, "|     "[u], "      "[If[#1 < Y, w, t]]][[m[X + #1]]] &],
     a["|_____" &]}
   ], "|\n"
 ] <> "|") &

2

แบตช์562 528 ไบต์

@echo off
set t=!  !
set w=%2
set a= _) (_!_   _! (_) !        _  !_( )_!_   _ _) (_
call:d "!     !_   _" 2 " _____ _____" 4
for /l %%j in (2,1,%1)do call:t
call:d "!_____!_____" 1 "%a:~18,6%%a:~-6%" 3
exit/b
:t
set a=%a:~24%%a:~0,24%
call:d "%a:~6,6%%a:~30,6%" 1 "%a:~0,6%%a:~24,6%" 3
call:c "%a:~12,6%%a:~36,6%" 2
exit/b
:d
call:c %3 %4
:c
set s=
for /l %%i in (%w%,-2,1)do call set s=%~1%%s%%&if %%i==1 call set s=%%s:~6%%
if %2 lss 4 set s=%s%!&call set s=%%t:~0,%2%%%%s:~%2,-%2%%%%t:~-%2%%
echo %s:!=^|%

พิสูจน์แล้วว่าทนทานต่อการเล่นกอล์ฟเนื่องจากการทำซ้ำมีแนวโน้มที่จะต้องเสียค่าใช้จ่ายมากเกินไปที่จะกำจัดตัวอย่างเช่นฉันผ่านด้วยตนเองในหมายเลขบรรทัด mod 3 เพราะมันแพงเกินไปที่จะคำนวณ แก้ไข: นอกจากนี้ฉันมีการตีกอล์ฟพิเศษ|ทุกบรรทัดที่สามซึ่งไม่ถูกต้อง การแก้ไขสิ่งนี้ช่วยฉันจริง ๆ 2 ไบต์ (4 ไบต์ในรุ่นเดิม) คำอธิบาย: aมีตัวต่อต่าง ๆ :tแลกเปลี่ยนการทำงานของพวกเขามากกว่าชุดของสามแถวแต่ละแล้วสารสกัดจากสตริงที่จำเป็นซึ่ง:cฟังก์ชั่นแล้วซ้ำในคู่ แต่การลบคอลัมน์แรกถ้าwเป็นเลขคี่ เคสขอบซ้ายและขวาจะได้รับการจัดการก่อนที่แถวจะออก กรณีขอบอื่น ๆ เป็นแถวแรกที่!มีการเปลี่ยน s เป็นช่องว่างแทน|s (รหัสหลีกเลี่ยง|เพราะพวกเขามีความยุ่งยากในการจัดการในแบทช์)


2

Befunge, 263 243 ไบต์

|_   _| (_)
 _) (_   _
|_   _|_( )_

|
|
|_____
 _____
>&:08p3*28p&:18p6*38pv
@#!`g82:,_v0+55+1p84:<_
\g82+g84<| `g83:+1,g\%*6-g852+*6/3+2g84\++%3+2\!:g84*4p85:!!+*`0%6\!*`
6/08g+2%^>>::::48g3/2%2*`\48g3/18g+2%!2*+38g\`*!48g3%0`*\::6/2%!48g\`\

ลองออนไลน์!

วิธีการทำงานนี้คือโดยการทำซ้ำมากกว่า x ที่ y พิกัดของพื้นที่ที่เราต้องการที่จะส่งออกและการทำแผนที่ผู้x , y ที่ค่าU , Vพิกัดในรูปแบบจิ๊กซอว์ (เก็บไว้ในสามบรรทัดแรกของสนามแข่งขัน) การจับคู่นี้ทำได้ด้วยสูตรพื้นฐานต่อไปนี้:

u = (x+(y+2)/3*6) % 12
v = (y+2)%3 + (y==0)

Uประสานงานซ้ำทุก 12 คอลัมน์ แต่ยังต้องมีการชดเชยโดย 6 ทุก 3 แถว วีประสานงานซ้ำทุก 3 แถว แต่เราเพิ่มy==0ค่าเพื่อให้แถวแรกมากสามารถแสดงผลเป็นกรณีพิเศษ อย่างไรก็ตามในการจัดการกับขอบที่เราต้องแนะนำเพิ่มเติมบูลค่าอีที่เป็นจริงสำหรับสถานที่ขอบต่างๆและที่ปรับสูตรดังต่อไปนี้:

u = (x+(y+2)/3*6) % (e?6:12)
v = (y+2)%3 + (y==0) + e*4

ดังนั้นถ้าเราอยู่บนขอบเราเพิ่ม 4 ลงในพิกัดvเพื่อใช้รูปแบบขอบที่ง่ายกว่าบนบรรทัดที่ 5 ถึง 7 และตอนนี้เราก็ต้องแก้ไขพิกัดuด้วย 6 แทนที่จะเป็น 12 เพราะรูปแบบขอบนี้ ทำซ้ำทุก 6 คอลัมน์

สำหรับค่าeนั้นต้องใช้สูตรที่ค่อนข้างซับซ้อนเนื่องจากตำแหน่งขอบนั้นครอบคลุมพื้นที่ที่ค่อนข้างผิดปกติของเส้นขอบตัวต่อ

elr = (x <= 2*y/3%2 or x >= w-2*!(y/3+cols)%2) and (y%3 > 0)
etb = (y <= !(x/6%2) or y >= h-(x/6+rows)%2) and (x%6 > 0)
e   = elr or etb

การแบ่งขั้นพื้นฐานคือelrจับคู่ตำแหน่งขอบตามขอบด้านซ้ายและด้านขวาในขณะที่etbจับคู่ตำแหน่งตามแนวขอบด้านบนและด้านล่าง


1

JavaScript (ES6), 285 ไบต์

f=
(h,w,a=` _) (_|_   _| (_)    _  |_( )_|_   _      |     |_____`.match(/.{6}/g),g=(l,r,j)=>a[7].slice(0,j)+(a[l]+a[r]).repeat(w).slice(j,w*6+1-j)+`  |`.slice(-j))=>[` _____`.repeat(w),g(1,7,2),...[...Array(--h*3)].map((_,i)=>g(i%6,(i+3)%6,"312"[i%3])),g(h=h%2*6,6-h,3),g(8,8,1)].join`
`
<div oninput=o.textContent=+h.value&&+w.value?f(h.value,w.value):''><input id=h type=number min=1><input id=w type=number min=1><pre id=o>

นี่คือพอร์ตของคำตอบแบทช์ของฉันเพียงเพื่อดูว่ามันแข่งขันกับคำตอบของ @ edc65 สายยาวที่น่ารำคาญประกอบด้วยชิ้นส่วนจิ๊กซอว์ หกชิ้นแรกแสดงสองแถวของหนึ่งคอลัมน์ของการตกแต่งภายในของจิ๊กซอว์ ชิ้นที่เจ็ดใช้สำหรับเส้นต่อท้ายของจิ๊กซอว์แทนที่ชิ้นที่สี่ ใช้ชิ้นที่แปดในบรรทัดที่สองของจิ๊กซอว์แทนที่ชิ้นที่ห้าและยังทำหน้าที่เป็นสองเท่าขอบด้านซ้ายของจิ๊กซอว์ ชิ้นที่เก้าเป็นบรรทัดสุดท้ายของจิ๊กซอว์

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.