ถอดรหัสแผนที่ความร้อน


32

heatmaps

ลองพิจารณาห้องรูปสี่เหลี่ยมผืนผ้าบนเพดานที่เรามีกล้องความร้อนชี้ลง ในห้องพักมีจำนวนบางแหล่งความร้อนของความเข้มอุณหภูมิพื้นหลังเป็น1-9 0ความร้อนจะหายไปจากแหล่งกำเนิดแต่ละหยดโดยหนึ่งหน่วยต่อขั้นตอน (ไม่ใช่แนวทแยงมุม) ตัวอย่างเช่น20x10ห้อง

...........1........
....................
...8................
..5...............2.
....................
.1..................
................1...
.................65.
....................
............2.......

มีแหล่งความร้อน 9 แหล่งและมีการไล่ระดับอุณหภูมิที่แสดงโดยกล้องความร้อน

34565432100100000000
45676543210000000000
56787654321000000110
45676543210000001221
34565432100000012321
23454321000000123432
12343210000001234543
01232100000012345654
00121000000011234543
00010000000121123432

ในรูปแบบกราฟิกนี้อาจมีลักษณะ:

heatmap จาก 9 แหล่ง

จากการไล่ระดับสีเราสามารถอนุมานตำแหน่งและความเข้มของแหล่งความร้อนบางส่วน แต่ไม่ใช่ทั้งหมด ตัวอย่างเช่น9s ทั้งหมดสามารถอนุมานได้เสมอเนื่องจากมีอุณหภูมิสูงสุดและสามารถทำได้8ในกรณีนี้เนื่องจากสร้างค่าสูงสุดในพื้นที่ในการไล่ระดับสี 2ใกล้ชายแดนที่เหมาะสมนอกจากนี้ยังสามารถอนุมานแม้ว่ามันจะไม่ได้อยู่ที่สูงสุดในท้องถิ่นเพราะมันไม่ได้มีอีก2เป็นเพื่อนบ้าน 5s บนมืออื่น ๆ ที่ยังไม่ได้สรุปเนื่องจากความร้อนของพวกเขาเช่นกันอาจจะเกิดจากแหล่งที่รุนแรงมากขึ้นใกล้พวกเขา 0s เป็นที่รู้จักกันไม่มีแหล่งความร้อน แต่ทั้งหมดกระเบื้องอื่น ๆ อาจอาจมีหนึ่ง ลองแทนกระเบื้องที่ไม่แน่นอนด้วยเครื่องหมายยัติภังค์-แหล่งความร้อนบางตัวโดยตัวเลขที่สอดคล้องกันและบางพื้นที่ว่างตามระยะเวลา.:

---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------

งานของคุณคือการสร้างรูปแบบอนุมานนี้จากการไล่ระดับอุณหภูมิ

กฎระเบียบ

คุณจะได้รับอินพุตเป็นสตริงที่คั่นด้วยการขึ้นบรรทัดใหม่หรือไพพ์แนวตั้ง|แล้วแต่จำนวนใดจะสะดวกกว่าและเอาต์พุตจะเป็นรูปแบบเดียวกัน อาจมีตัวคั่นต่อท้ายในอินพุตและ / หรือเอาท์พุท แต่ไม่มีก่อนหน้า ขนาดของการป้อนข้อมูลที่อาจแตกต่างกัน 4แต่ความกว้างและความสูงของมันอยู่เสมออย่างน้อย ทั้งฟังก์ชั่นและโปรแกรมเต็มรูปแบบเป็นที่ยอมรับ จำนวนไบต์ต่ำสุดที่ชนะและช่องโหว่มาตรฐานเป็นสิ่งต้องห้าม

กรณีทดสอบเพิ่มเติม

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

898778765432100
787667654321100
677656543211210
678765432112321
567654321123210

ซึ่งมีลักษณะเช่นนี้ในรูปแบบกราฟิก:

กรณีทดสอบ 1

เอาท์พุท:

-9---8-------..
-------------..
--------------.
--8---------3--
-----------3--.

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

7898
8787
7676
6565

เอาท์พุท:

--9-
8---
----
----

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

00001
00000
00000
10000

เอาท์พุท:

....1
.....
.....
1....

1
คุณรังเกียจไหมถ้าฉันเพิ่มกราฟิกความร้อน 2 กราฟิกลงในคำถามของคุณหากคุณคิดว่าพวกเขาเพิ่มมูลค่า พวกเขาเป็นเพียงการทดลอง 2 นาที
Logic Knight อัศวิน

@CarpetPython แน่นอนไปเลย พวกเขาดูดีมากสำหรับฉัน คุณยังสามารถเพิ่ม "ความอนุเคราะห์ของ CarpetPython" เพื่อมอบเครดิตให้ตัวคุณเอง ;)
Zgarb

2
เสร็จสิ้น ไม่ต้องใช้เครดิต แต่ฉันคิดว่ามันหยาบคายที่จะไม่ถามก่อนทำการแก้ไข
Logic Knight อัศวิน

ทำไมไม่อนุญาตให้อินพุตเป็นอาร์เรย์ 2 มิติแทนที่จะเป็นสตริง
feersum

@feersum โดยทั่วไปวิธีการป้อนข้อมูลมีความสอดคล้อง
เครื่องมือเพิ่มประสิทธิภาพ

คำตอบ:


10

CJam, 73 69 62 55 ไบต์

UPDATE : อัลกอริทึมใหม่ ขอบเขตที่สั้นลงสำหรับการปรับปรุง

qN/5ff*{{[{_@_@<{I'0t}*\}*]W%}%z}4fI{):X-'-X~X'.??}f%N*

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

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

  • แปลงอักขระแต่ละตัวเป็นชุด 5 4 ตัวแรกจะถูกปรับเปลี่ยนเพื่อบอกว่าใหญ่กว่าเซลล์ที่อยู่ติดกันในแถวขณะทำซ้ำหรือไม่ อันสุดท้ายคือเพื่อการเปรียบเทียบ
  • ทำซ้ำในแต่ละแถวและลดในแต่ละแถว ขณะที่ลดขนาดฉันมีสตริงอักขระ 5 ตัวสองตัว ฉันรู้ว่าการวนซ้ำคืออะไร [0 สำหรับแถวปกติ, 1 คอลัมน์ที่กลับด้าน, 2 สำหรับแถวที่กลับด้านและ 3 สำหรับคอลัมน์ปกติ] ฉันอัปเดตตัวอักษรi thในสตริงอักขระ 5 ตัวแรกและทำให้เป็น 0 ถ้ามันเล็กกว่าวินาที .
  • หลังจากการวนซ้ำทั้ง 4 ครั้งหากอักขระทั้ง 5 ตัวเหมือนกันและไม่เป็นศูนย์นั่นคือ maxima ท้องถิ่น I แผนที่ผ่านทุก 5 สตริงตัวอักษรและแปลงให้เป็นอย่างใดอย่างหนึ่งหลักเดียวหรือ.-

นี่คือตัวอย่างการรันบนอินพุตขนาดเล็ก:

7898
8787
7676
6565

หลังจากขั้นตอนแรก:

["77777" "88888" "99999" "88888"
 "88888" "77777" "88888" "77777"
 "77777" "66666" "77777" "66666"
 "66666" "55555" "66666" "55555"]

หลังจากขั้นตอนที่สอง:

["00777" "08888" "99999" "88088"
 "88888" "07007" "88808" "77007"
 "77707" "06006" "77707" "66006"
 "66606" "05005" "66606" "55005"]

หลังจากการจับคู่ครั้งล่าสุดกับตัวอักขระเดียวเอาต์พุตสุดท้าย:

--9-
8---
----
----

คำอธิบายรหัส :

qN/5ff*                         "Split the input on new line and convert each character";
                                "to string of 5 of those characters.";
{{[{             }*]W%}%z}4fI   "This code block runs 4 times. In each iteration, it";
                                "maps over each row/column and then for each of them,";
                                "It reduce over all elements of the row/column";
                                "Using combination of W% and z ensures that both rows and";
                                "columns are covered and in both directions while reducing";
    _@_@                        "Take a copy of last two elements while reducing over";
        <                       "If the last element is bigger than second last:";
         {I'0t}*\               "Convert the Ith character of the 5 char string of"
                                "second last element to 0";
                                "We don't have to compare Ith character of last two 5 char";
                                "string as the smaller one will be having more leading";
                                "0 anyways. This saves 4 bytes while comparing elements";
{):X-'-X~X'.??}f%N*             "This part of code converts the 5 char back to single char";
 ):X                            "Remove the last character and store in X. This last char";
                                "was not touched in the prev. loop, so is the original char";
    -                           "Subtract X from remaining 4 char. If string is not empty";
                                "then it means that it was not all same characters";
                                "In other words, this character was smaller then neighbors";
     '-      ?                  "If non-empty, then replace with - else ...";
       X~X'.?                   "if int(X) is zero, put . else put X";
               f%N*             "The mapping code block was run for each row and then";
                                "The rows are joined by newline.";

ลองที่นี่


วิธีเก่ากว่า

qN/~_,):L0s*]0s*:Q_,{QI=:A[W1LL~)]If+Qf=$W=<'-A?A~\'.?I\t}fIL/W<Wf<N*

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

ตรรกะนั้นเรียบง่ายวนซ้ำผ่านกริดและดูว่าค่าปัจจุบันมากกว่าหรือเท่ากับเพื่อนบ้านทั้งสี่ที่เหลือ - ขึ้นลงซ้ายและขวา จากนั้นแปลงค่าปัจจุบันตามกฎข้างต้นและถ้าค่าเท่ากับ 0 ให้เปลี่ยนเป็น "." .

รหัสคำอธิบาย

qN/~_,):L0s*]0s*:Q         "This part of code pads the grid with 0s";
qN/~                       "Read the input, split on new lines and unwrap the arrays";
    _,):L                  "Copy the last row, taken length, increment and store in L";
         0s*               "Get L length 0 string";
            ]0s*           "Wrap everything in an array and join the rows by 0";
                :Q         "Store this final single string in Q";

_,{        ...      }fI    "Copy Q and take length. For I in 0..length, execute block";
   QI=:A                   "Get the I'th element from Q and store in A";
   [WiLL~)]If+             "This creates indexes of all 4 neighboring cells to the Ith cell";
              Qf=          "Get all 4 values on the above 4 indexes";
                 $W=       "Sort and get the maximum value";
<'-A?                      "If the current value is not the largest, convert it to -";
     A~\'.?                "If current value is 0, convert it to .";
           I\t             "Update the current value back in the string";
{ ... }fIL/                "After the loop, split the resulting string into chunks of L";
           W<Wf<           "Remove last row and last column";
                N*         "Join by new line and auto print";

ลองออนไลน์ได้ที่นี่


5
ฉันต้องบอกว่าฉันไม่ค่อยได้ยิน "นานเกินไป" เมื่ออธิบายรหัส CJam
Alex A.

6

JavaScript (ES6) 99

F=h=>[...h].map((c,i)=>[o=~h.search('\n'),-o,1,-1].some(d=>h[d+i]>c)&c>0?'-':c=='0'?'.':c).join('')

ทดสอบในคอนโซล Firefox / FireBug

console.log(F('\
34565432100100000000\n\
45676543210000000000\n\
56787654321000000110\n\
45676543210000001221\n\
34565432100000012321\n\
23454321000000123432\n\
12343210000001234543\n\
01232100000012345654\n\
00121000000011234543\n\
00010000000121123432\n'),'\n\n',
F('\
898778765432100\n\
787667654321100\n\
677656543211210\n\
678765432112321\n\
567654321123210\n'), '\n\n',
F('7898\n8787\n7676\n6565\n'))

เอาท์พุต

---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------


-9---8-------..
-------------..
--------------.
--8---------3--
-----------3--.


--9-
8---
----
----

4

Python 2: 154 ไบต์

b=input()
l=b.index('\n')+1
print''.join(('\n.'+('-'+v)[all([v>=b[j]for j in i-l,i-1,i+l,i+1if 0<=j<len(b)])])[('\n0'+v).index(v)]for i,v in enumerate(b))

"00001\n00000\n00000\n10000"การป้อนข้อมูลจะต้องมีรูปแบบ

การแปลงสตริงเป็น 2D-matrix ค่อนข้างยาวใน Python ดังนั้นฉันจึงคงรูปแบบสตริงดั้งเดิม ฉันแจกแจงมากกว่าอินพุตiเป็นดัชนีvเป็นตัวอักษร (ในที่สุดระบุจำนวนไบต์ที่บันทึกไว้ในโซลูชันกอล์ฟ !!) สำหรับแต่ละคู่(i,v)ฉันคำนวณการแสดงผลที่ถูกต้องและเข้าร่วม ฉันจะเลือกถ่านเอาต์พุตที่ถูกต้องได้อย่างไร ถ้าv == '\n'ถ่านออกเป็น\nมันกว่าถ่านออกเป็นv == '0' '.'มิฉะนั้นฉันจะทดสอบ 4 เพื่อนบ้านของvซึ่ง ได้แก่b[i-b.index('\n')-1](ด้านบน), b[i-1](ซ้าย, b[i+1](ขวา) และb[i+b.index('\n')+1](ใต้) หากพวกเขาเป็น<= vและเลือกถ่าน'-'หรือv. ที่นี่ฉันเปรียบเทียบตัวอักษรไม่ใช่ตัวเลข แต่ใช้งานได้ดีเพราะค่า ascii อยู่ในลำดับที่ถูกต้อง นอกจากนี้ยังมีปัญหาไม่มีถ้าb[i-1]หรือb[i+1]เท่ากับเพราะ'\n'ord('\n') = 10

Pyth: 61 58

JhxQbVQK@QN~k@++b\.?\-f&&gT0<TlQ<K@QT[tNhN-NJ+NJ)Kx+b\0K)k

การแปลของสคริปต์ Python มากขึ้นหรือน้อยลง ค่อนข้างน่าเกลียด ;-)

ลองใช้งานออนไลน์: Pyth Compiler / Executorรูปแบบอินพุตเหมือนกับโซลูชัน Python

JhxQb      Q = input()
  xQb      Q.index('\n')
 h         +1
J          store in J

VQK@QN~k.....)k   k is initialized as empty string
VQ           )    for N in [0, 1, 2, ..., len(Q)-1]:
  K@QN                K = Q[n]
      ~k              k += ... (a char, computed in the next paragraph)
             )    end for
              k   print k

@...x+b\0K   ... is a char of len 3 (is constructed below)
     +b\0    the string "\n0"
    x    K   find Q[d] in this string and return index, if not found -1
@...         lookup in string at the computed position (this is done mod 3 automatically!)

++b\.?\-f&&gT0<TlQ<K@QT[tNhN-NJ+NJ)K   not to the string
                       [tNhN-NJ+NJ)    the list [d-1, d+1, d-J, d+j]
        f                              filter the list for indices T which
           gT0                            T >= 0
          &                               and
              <TlQ                        T < len(Q)
         &                                and
                  <K@QT                   Q[d] < Q[T]
     ?\-                           K   use "-" if len(filter) > 0 else Q[d]
                                       this creates the third char
++b\.                                  "\n" + "." + third char

4

Perl, 77, 75, 72 70

เทคนิคการจับคู่ regex มาตรฐาน 2d

#!perl -p0
/
/;$x="(.{@-})?";y/0/./while s/$.$x\K$"|$"(?=$x$.)/-/s||($"=$.++)<9

ตัวอย่าง:

$ perl heat.pl <in.txt
---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------

ลองที่นี่


3

Java, 307 , 304 , 303 , 299 298

นี่เป็นความท้าทายอย่างสมบูรณ์แบบสำหรับ codegolf ของ Java :)

class M{public static void main(String[]a){int c=a[0].indexOf('|'),i=c,d,v;char[]r=a[0].replace("|","").toCharArray(),m=new char[(v=r.length+c)+c];for(;i<v;){m[i]=r[i++-c];}for(i=c;i<v;i++){a[0]=i%c<1?"\n":"";d=m[i];System.out.print(a[0]+(d<49?'.':m[i-c]>d|m[i+c]>d|m[i-1]>d|m[i+1]>d?'-':m[i]));}}}

วิธีการป้อนข้อมูล (ไพพ์ '|'):

34565432100100000000|45676543210000000000|56787654321000000110|45676543210000001221|34565432100000012321|23454321000000123432|12343210000001234543|01232100000012345654|00121000000011234543|00010000000121123432

เอาท์พุท:

---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------

1
นี่อาจเป็น 288 ถ้าคุณลบที่ว่างchar[]r=a[0].replace("|", <--here"").toCharArray()ออก
bcsb1001

1
ไม่พบจุดนั้นขอบคุณ! นี่ทำให้ 298
Rolf ツ

2

APL, 92

('.-',⎕D)[1+(M≠0)+M{(1+⍺)×0≠⍺∧M[J/⍨Z∊⍨J←⍵∘+¨(⌽¨,+)(-,+)⊂0 1]∧.≤⍺}¨Z←⍳⍴M←↑{×⍴⍵:(⊂⍎¨⍵),∇⍞⋄⍬}⍞]

ตัวอย่าง:

       ('.-',⎕D)[1+(M≠0)+M{(1+⍺)×0≠⍺∧M[J/⍨Z∊⍨J←⍵∘+¨(⌽¨,+)(-,+)⊂0 1]∧.≤⍺}¨Z←⍳⍴M←↑{×⍴⍵:(⊂⍎¨⍵),∇⍞⋄⍬}⍞]
34565432100100000000
45676543210000000000
56787654321000000110
45676543210000001221
34565432100000012321
23454321000000123432
12343210000001234543
01232100000012345654
00121000000011234543
00010000000121123432

---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------

โปรแกรม APL ที่ยาวที่สุดที่ฉันเคยเห็น คุณอาจต้องการทราบว่านี่ไม่ใช่ APL มาตรฐานเนื่องจากใช้ dfns
FUZxxl

2

ทับทิม 140

f=->s{
r=s.dup
l=s.index(?\n)+1
(0...s.size).map{|i|
s[i]<?0||r[i]=r[i]<?1??.:[i-1,i+1,i-l,i+l].map{|n|n<0??0:s[n]||?0}.max>r[i]??-:s[i]}
r}

ไม่มีอะไรพิเศษ; แค่วนซ้ำแผนที่และเปรียบเทียบมูลค่าปัจจุบันกับมูลค่าของเพื่อนบ้านทั้งสี่

เปิดใช้งานออนไลน์ด้วยการทดสอบ: http://ideone.com/AQkOSY


1

R, 223

เกี่ยวกับสิ่งที่ดีที่สุดที่ฉันสามารถทำได้ในตอนนี้ การจัดการกับสายนั้นค่อนข้างแพง ฉันคิดว่ามีห้องพักสำหรับการปรับปรุง แต่ไม่สามารถดูได้ในขณะนี้

s=strsplit;a=c(m<-do.call(rbind,s(s(scan(w="c"),'|',T)[[1]],'')));w=(d<-dim(m))[1];n=c(-1,1,-w,w);cat(t(array(sapply(seq(a),function(x)if(a[x]>0)if(any(a[(n+x)[which(n+x>0)]]>a[x]))'-'else a[x]else'.'),d)),fill=d[2],sep='')

ผลการทดสอบ

> s=strsplit;a=c(m<-do.call(rbind,s(s(scan(w="c"),'|',T)[[1]],'')));w=(d<-dim(m))[1];n=c(-1,1,-w,w);cat(t(array(sapply(seq(a),function(x)if(a[x]>0)if(any(a[(n+x)[which(n+x>0)]]>a[x]))'-'else a[x]else'.'),d)),fill=d[2],sep='')
1: 898778765432100|787667654321100|677656543211210|678765432112321|567654321123210
2: 
Read 1 item
-9---8-------..
-------------..
--------------.
--8---------3--
-----------3--.
> s=strsplit;a=c(m<-do.call(rbind,s(s(scan(w="c"),'|',T)[[1]],'')));w=(d<-dim(m))[1];n=c(-1,1,-w,w);cat(t(array(sapply(seq(a),function(x)if(a[x]>0)if(any(a[(n+x)[which(n+x>0)]]>a[x]))'-'else a[x]else'.'),d)),fill=d[2],sep='')
1: 34565432100100000000|45676543210000000000|56787654321000000110|45676543210000001221|34565432100000012321|23454321000000123432|12343210000001234543|01232100000012345654|00121000000011234543|00010000000121123432
2: 
Read 1 item
---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------
> 

1

J - 69 ไบต์

[:u:45+[:(+2 0 3{~"#1+*)@((]*]=(0,(,-)1 0,:0 1)>./@:|.])-0=])"."0;._2

ตัวอย่าง:

   ([:u:45+[:(+2 0 3{~"#1+*)@((]*]=(0,(,-)1 0,:0 1)>./@:|.])-0=])"."0;._2) (0 : 0)
34565432100100000000
45676543210000000000
56787654321000000110
45676543210000001221
34565432100000012321
23454321000000123432
12343210000001234543
01232100000012345654
00121000000011234543
00010000000121123432
)
---------..1........
----------..........
---8-------......--.
----------......--2-
---------......-----
--------......------
-------......-------
.-----......-----6--
..---.......--------
...-.......-2-------
   ([:u:45+[:(+2 0 3{~"#1+*)@((]*]=(0,(,-)1 0,:0 1)>./@:|.])-0=])"."0;._2) (0 : 0)
898778765432100
787667654321100
677656543211210
678765432112321
567654321123210
)
-9---8-------..
-------------..
--------------.
--8---------3--
-----------3--.

PS: (0 : 0)เป็นวิธีมาตรฐาน J ของการระบุสตริง คุณอาจใช้|สตริงที่มีตัวคั่น (เช่นกับการต่อท้าย|)


1

Excel VBA - 426

มันจะเป็นโอกาสที่หายากที่ VBA ชนะเกมการแข่งขันกอล์ฟรหัสใด ๆ แต่เนื่องจากเป็นสิ่งที่ฉันใช้มากที่สุดมันสนุกที่จะเล่นกับมัน บรรทัดแรกเป็นตัวพิมพ์ขอบที่ทำให้ยาวกว่าที่ควรจะเป็น

Sub m(a)
    b = InStr(a, "|")
    For i = 1 To Len(a)
        t = Mid(a, i, 1)
        Select Case t
            Case "|"
                r = r & "|"
            Case 0
                r = r & "."
            Case Else
                On Error Resume Next
                x = Mid(a, i - 1, 1)
                y = Mid(a, i + 1, 1)
                Z = Mid(a, i + b, 1)
                If i < b Then
                    If t < x Or t < y Or t < Z Then
                        r = r & "-"
                    Else
                        r = r & t
                    End If
                Else
                    If t < x Or t < y Or t < Z Or t < Mid(a, i - b, 1) Then
                        r = r & "-"
                    Else
                        r = r & t
                    End If
                End If
        End Select
    Next
    MsgBox r
End Sub

การนับไม่รวมช่องว่างบรรทัดเริ่มต้น

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

โทรจากหน้าต่างทันที:

m "34565432100100000000|45676543210000000000|56787654321000000110|45676543210000001221|34565432100000012321|23454321000000123432|12343210000001234543|01232100000012345654|00121000000011234543|00010000000121123432"

เอาท์พุท (ในหน้าต่าง):

---------..1........|----------..........|---8-------......--.|----------......--2-|---------......-----|--------......------|-------......-------|.-----......-----6--|..---.......--------|...-.......-2-------

1

Perl - 226

sub f{for(split'
',$_[0]){chomp;push@r,r($_);}for(t(@r)){push@y,r($_)=~s/0/./gr}$,=$/;say t(@y);}sub r{$_[0]=~s/(?<=(.))?(.)(?=(.))?/$1<=$2&&$3<=$2?$2:$2eq'0'?0:"-"/ger;}sub t{@q=();for(@_){for(split//){$q[$i++].=$_;}$i=0;}@q}

คุณสามารถลองideone หากใครสนใจคำอธิบายแจ้งให้เราทราบ


ฉันคิดว่าคุณมี 226 ตัวอักษรไม่ใช่ 227
Cristian Lupascu

@ w0lf คุณพูดถูกขึ้นบรรทัดใหม่นับเป็น 2 เนื่องจากฉันใช้ Windows
hmatt1

1

Haskell - 193

z='0'
r=repeat z
g s=zipWith3(\u t d->zip3(zip(z:t)u)t$zip(tail t++[z])d)(r:s)s$tail s++[r]
f=unlines.map(map(\((l,u),t,(r,d))->case()of _|t==z->'.'|maximum[u,l,t,r,d]==t->t|0<1->'-')).g.lines

fคือ funtion ที่รับสตริงในรูปแบบ0001\n0000\n0000\n1000และส่งคืนสตริงที่ต้องการ

g เป็นฟังก์ชั่นที่รับรายการของตัวอักษรและส่งกลับรายการของ ((ซ้าย, ขึ้น), สิ่งนี้, (ขวา, ลง)

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