วาดเส้นทางที่ทำโดยตัวเปลี่ยนทิศทาง


25

ความท้าทายนี้เกิดขึ้นบนกริด

+----------+
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
+----------+

อันนี้ 10 x 10 แต่มันอาจเป็นรูปสี่เหลี่ยมผืนผ้าก็ได้

มีสี่ทิศทางในตารางนี้ ขึ้นลงซ้ายและขวา

ภารกิจคือการวาดเส้นทางที่เริ่มต้นด้วยทิศทางตัวพิมพ์ใหญ่เริ่มต้น ในตัวอย่างนี้จะขึ้นตรงจากสหรัฐฯ

+----------+
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|   U      |
+----------+

พา ธ จะขึ้นไปข้างบนและประกอบด้วยตัวอักษรครบวงจร (.) จนกระทั่งมันกระทบกับกำแพงเมื่อมันสิ้นสุดด้วยเครื่องหมายดอกจัน (*)

+----------+
|   *      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

นอกเหนือจากการเริ่มต้นเส้นทางแล้วยังมีตัวเปลี่ยนทิศทางแสดงด้วยทิศทางตัวพิมพ์เล็กเริ่มต้น

+----------+
|          |
|          |
|          |
|   r.....*|
|   .      |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

นอกจากนี้ตัวพิมพ์ใหญ่ X ยังมีสิ่งกีดขวางซึ่งจะยุติเส้นทาง

+----------+
|          |
|          |
|          |
|          |
|   r...*X |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

กฎระเบียบ

  • อินพุตเป็นสตริงที่ประกอบด้วยเฟรม (ประกอบด้วยอักขระ |, - และ +) ที่มีอักขระที่แสดงถึงการเริ่มต้นเส้นทาง, ตัวเปลี่ยนทิศทางและอุปสรรค
  • รหัสของคุณควรเพิ่มอักขระหยุดเต็มเพื่อติดตามเส้นทางที่อธิบายโดยเริ่มต้นและตัวเปลี่ยนทิศทางและเครื่องหมายดอกจันเมื่อ / หากเส้นทางตรงกับกำแพงหรือสิ่งกีดขวาง
  • อาจมีหลายเส้นทางเริ่ม
  • รหัสจะยังคงสิ้นสุดลงโดยไม่มีข้อผิดพลาดหากเส้นทางอธิบายลูป
  • หากเส้นทางตรงกับการเริ่มต้นเส้นทางมันจะทำหน้าที่เป็นตัวเปลี่ยนทิศทาง
  • มันคือรหัสกอล์ฟรหัสต่ำไบต์และไม่มีช่องว่างมาตรฐาน
  • ฉันชอบลิงค์ไปยังล่ามออนไลน์

กรณีทดสอบ

1: เรียบง่าย

+----------+
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|   U      |
+----------+


+----------+
|   *      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

2: เลี้ยวขวา

+----------+
|          |
|          |
|          |
|   r      |
|          |
|          |
|          |
|          |
|   U      |
+----------+


+----------+
|          |
|          |
|          |
|   r.....*|
|   .      |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

3: ทางแยก

+----------+
|          |
|          |
|          |
|   r  d   |
|          |
| u    l   |
|          |
|          |
|   U      |
+----------+


+----------+
| *        |
| .        |
| .        |
| . r..d   |
| . .  .   |
| u....l   |
|   .      |
|   .      |
|   U      |
+----------+

4: 4 เส้นทางที่ข้าม

+----------+
|      D   |
|          |
|          |
|R         |
|          |
|         L|
|          |
|          |
|   U      |
+----------+


+----------+
|   *  D   |
|   .  .   |
|   .  .   |
|R........*|
|   .  .   |
|*........L|
|   .  .   |
|   .  .   |
|   U  *   |
+----------+

5: วงแรก

+----------+
|          |
|          |
|          |
|   r  d   |
|          |
|   u  l   |
|          |
|          |
|   U      |
+----------+

+----------+
|          |
|          |
|          |
|   r..d   |
|   .  .   |
|   u..l   |
|   .      |
|   .      |
|   U      |
+----------+

6: เริ่มต้นเป็นผู้เปลี่ยน

+----------+
|          |
|          |
|          |
|   L      |
|          |
|          |
|          |
|          |
|   U      |
+----------+


+----------+
|          |
|          |
|          |
|*..L      |
|   .      |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

7: วงตรง

+----------+
|          |
|          |
|          |
|          |
|   r  l   |
|          |
|          |
|          |
|   U      |
+----------+


+----------+
|          |
|          |
|          |
|          |
|   r..l   |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+

8: ปมแน่น

+----------+
|          |
|          |
|          |
|  d  l    |
|   r u    |
|  r u     |
|          |
|          |
|   U      |
+----------+


+----------+
|    *     |
|    .     |
|    .     |
|  d..l    |
|  .r.u    |
|  r.u     |
|   .      |
|   .      |
|   U      |
+----------+

9: อุปสรรค

+----------+
|          |
|          |
|          |
|          |
|   r    X |
|          |
|          |
|          |
|   U      |
+----------+


+----------+
|          |
|          |
|          |
|          |
|   r...*X |
|   .      |
|   .      |
|   .      |
|   U      |
+----------+ 

10: รูปร่าง

+----------+
|r     d   |
|          |
|  XXXXXXXX|
| d      l |
|ul        |
|XXXXXXX   |
|          |
|R       u |
|          |
+----------+


+----------+
|r.....d   |
|.     *   |
|. XXXXXXXX|
|.d......l |
|ul      . |
|XXXXXXX . |
|        . |
|R.......u |
|          |
+----------+

11: 4-Knot Way

+----------+
|      D   |
|          |
|   r      |
|R    d    |
|          |
|    u    L|
|      l   |
|          |
|   U      |
+----------+


+----------+
|    * D   |
|    . .   |
|   r.....*|
|R....d.   |
|   ....   |
|   .u....L|
|*.....l   |
|   . .    |
|   U *    |
+----------+

12: ทางแยกไม่ว่าง

+----------+
|rrrrr rrrd|
| rlrl     |
|ul rrd    |
|ruX X     |
|udl ll    |
|ull       |
|rlr       |
|rdr  d    |
|Uruull    |
+----------+


+----------+
|rrrrr.rrrd|
|.rlrl    .|
|ul rrd   .|
|ruX.X.   .|
|udl.ll   .|
|ull.     .|
|rlr.     .|
|rdr..d   .|
|Uruull   *|
+----------+

13: เริ่มเข้าสู่ Edge

+----------+
|   U      |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
+----------+

+----------+
|   U      |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
|          |
+----------+

14: การข้ามเส้นทางที่ตายแล้ว

+----------+
|          |
|          |
|          |
|      R   |
|          |
|          |
|          |
|          |
|         U|
+----------+


+----------+
|         *|
|         .|
|         .|
|      R..*|
|         .|
|         .|
|         .|
|         .|
|         U|
+----------+

@TFeld เพิ่มแล้วขอบคุณ!
AJFaraday

1
ดูเหมือนว่าจะมีการเปลี่ยนทิศทางทั้งหมดในกรณีทดสอบของคุณซึ่งอาจทำให้ขั้นตอนวิธีง่ายขึ้น ฉันขอแนะนำให้เพิ่มกรณีทดสอบที่ไม่เป็นความจริง
Arnauld

@Arnauld ฉันค่อนข้างแน่ใจว่ามีการเปลี่ยนทิศทางที่ไม่ได้ใช้ในกรณีที่ 12
AJFaraday


3
มีการระบุว่ากริดสามารถเป็นรูปสี่เหลี่ยมผืนผ้าใด ๆ แต่กรณีทดสอบทั้งหมดดูเหมือนจะมีขนาดและรูปร่างเหมือนกัน
Gastropner

คำตอบ:


9

JavaScript (ES6),  191 183  181 ไบต์

ขอบคุณ @tsh ที่ช่วยแก้ไขข้อผิดพลาด

รับอินพุตเป็นเมทริกซ์ของอักขระ เอาท์พุทโดยการปรับเปลี่ยนอินพุต

f=(a,X,Y,d,n=0)=>a.map((r,y)=>r.map((v,x)=>(a+0)[i=' .*dlurDLUR'.indexOf(v),n]?X?X-x+~-d%2|Y-y+(d-2)%2?0:~i?f(a,x,y,i>2?i&3:d,n+1,r[x]=i?v:'.'):n?a[Y][X]='*':0:i>6&&f(a,x,y,i&3):0))

ลองออนไลน์!

แสดงความคิดเห็น

f = ( a,                           // a[]  = input matrix
      X, Y,                        // X, Y = coordinates of the previous cell
      d,                           // d    = current direction (0 .. 3)
      n = 0                        // n    = number of iterations for the current path
    ) =>                           //
  a.map((r, y) =>                  // for each row r[] a position y in a[]:
    r.map((v, x) =>                //   for each character v at position x in r[]:
      (a + 0)[                     //
        i = ' .*dlurDLUR'          //     i = index of the character
            .indexOf(v),           //     blocking characters '-', '|' and 'X' gives -1
        n                          //     by testing (a + 0)[n], we allow each cell to be
      ]                            //     visited twice (once horizontally, once vertically)
      ?                            //     if it is set:
        X ?                        //       if this is not the 1st iteration:
          X - x + ~-d % 2 |        //         if x - X is not equal to dx[d]
          Y - y + (d - 2) % 2 ?    //         or y - Y is not equal to dy[d]:
            0                      //           ignore this cell
          :                        //         else:
            ~i ?                   //           if this is not a blocking character:
              f(                   //             do a recursive call:
                a,                 //               pass a[] unchanged
                x, y,              //               pass the coordinates of this cell
                i > 2 ? i & 3 : d, //               update d if v is a direction char.
                n + 1,             //               increment n
                r[x] = i ? v : '.' //               if v is a space, set r[x] to '.'
              )                    //             end of recursive call
            :                      //           else (this is a blocking character):
              n ?                  //             if this is not the 1st iteration:
                a[Y][X] = '*'      //               set the previous cell to '*'
              :                    //             else:
                0                  //               do nothing
        :                          //       else (1st iteration):
          i > 6 &&                 //         if v is a capital letter:
            f(a, x, y, i & 3)      //           do a recursive call with this direction
      :                            //     else ((a + 0)[n] is not set):
        0                          //       we must be in an infinite loop: abort
    )                              //   end of inner map()
  )                                // end of outer map()

btw [...""+a].mapสามารถสร้างอาร์เรย์ที่มีความยาวอย่างน้อย 2x ของ a ฉันไม่แน่ใจว่ามันจะช่วย
tsh

(a+0)[n]จะบันทึกไบต์แม้ว่าnตอนนี้จะต้องมีการเริ่มต้น
Arnauld

8

Python 2 , 283 279 293 288 279 ไบต์

e=enumerate
def f(M):
 s=[(x,y,c)for y,l in e(M)for x,c in e(l)if'A'<c<'X'];v=set(s)
 for x,y,C in s:
	d=ord(C)%87%5;q=d>1;X,Y=x-d+q*3,y+~-d-q;c=M[Y][X];N=(X,Y,[C,c]['a'<c<'x'])
	if'!'>c:M[Y][X]='.'
	if(c in'-|X')*('/'>M[y][x]):M[y][x]='*'
	if(c in'udlr. *')>({N}<v):v|={N};s+=N,

ลองออนไลน์!

ใช้รายการของรายการ

เอาต์พุตโดยการแก้ไขอาร์เรย์อินพุต


6

Perl 5, 203 188 166 ไบต์

$l='\K[ a-z](?=';$t='([-|X])?';$s=$_;/
/;$n='.'x"@-";{$_|=s/(?|R[.*]*$l$t)|$t${l}[.*]*L)|D$n(?:[.*]$n)*$l$n$t)|$t$n$l$n([.*]$n)*U))/$&eq$"?$1?'*':'.':uc$&/es?redo:$s}

TIO

มันทำงานอย่างไร

  • $s=$_เพื่อบันทึกอินพุตลงใน$sการกู้คืนตัวพิมพ์เล็ก $_|=$sเพราะบิตหรือพื้นที่จะไม่เปลี่ยนแปลง.และ*อักษรตัวพิมพ์เล็กurldจะถูกกู้คืนด้วยค่าบิตหรือการดำเนินการ
  • /\n/;$n='.'x"@-" เพื่อรับ "ความกว้าง" และ $nเพื่อให้ตรงกับอักขระ "ความกว้าง" ครั้ง
  • $l='\K[ a-z](?=';$t='([-|X])?'เพื่อลดความยาวของ regex $lเพื่อให้ตรงกับอักษรตัวพิมพ์เล็กurldหรือช่องว่างบนเส้นทาง$tเพื่อให้ตรงกับตัวยุติ

หลังจากเปลี่ยน: (?| R[.*]*\K[ a-z](?=([-|X])?) | ([-|X])?\K[ a-z](?=[.*]*L) | D$n(?:[.*]$n)*\K[ a-z](?=$n([-|X])?) | ([-|X])?$n\K[ a-z](?=$n([.*]$n)*U) )

  • สลับ/eไปที่ eval/sดังนั้น. (ภายใน$n) ตรงกับอักขระขึ้นบรรทัดใหม่
  • $&eq$"?$1?'*':'.':uc$&ถ้าจับคู่เป็นช่องว่างถ้า termiator จับคู่เป็น*อย่าง.อื่น

1
@Arnauld ใช้งานได้ถ้าคุณป้อนกรณีทดสอบครั้งละหนึ่งรายการ
Shaggy

ใช่ฉันโพสต์อย่างรวดเร็วและไม่สามารถตรวจสอบได้ว่าได้รับการแก้ไขแล้ว$sในส่วนท้าย $sใช้เพื่อบันทึกอินพุตและเพื่อปรับอักษรตัวพิมพ์เล็กเนื่องจากถูกสลับเป็นตัวพิมพ์ใหญ่เมื่อวาดเส้นทาง
Nahuel Fouilleul

4

ทำความสะอาด , 409 ไบต์

import StdEnv,Data.List
q=flatlines
$m=foldl(zipWith\a b|a=='*'||b=='*'='*'=max a b)(q m)[q(foldl(\m(_,y,x)=[[if(b<>x||a<>y)if(k=='*')'.'k'*'\\k<-r&b<-[0..]]\\r<-m&a<-[0..]])m(last(takeWhile(not o hasDup)(inits(f 0y 0x)))))\\l<-m&y<-[0..],c<-l&x<-[0..]|isUpper c]
where f a y b x=let(u,v)=(a+y,b+x)in(case toLower((m!!u)!!v)of' '=[((a,b),u,v):f a u b v];'r'=f 0u 1v;'l'=f 0u -1v;'u'=f -1u 0v;'d'=f 1u 0v;_=[])

ลองออนไลน์!


3

Python 2 , 250 ไบต์

def f(G,e=enumerate):
 for i,k in e(G):
	for j,l in e(k):
	 v=X=x=y=m,=l,
	 while(m in'-X|')<(l in'DLRU')>(X in v):v+=X,;y,x=zip((1,0,0,-1,y),(0,-1,1,0,x))['DLRU dlru'.find(m)%5];G[i][j]=(m,'.*'[G[i+y][j+x]in'-X|'])[m<'!'];i+=y;j+=x;X=x,i,j;m=G[i][j]

ลองออนไลน์!

ทำรายการของรายการของสตริง 1-char ตามที่อนุญาตโดย OP

เปลี่ยนรายการในสถานที่

สำหรับง่าย I / O ใช้นี้

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