*** *** ภูมิทัศน์


28

วัตถุประสงค์ : เขียนโปรแกรมที่สร้างทิวทัศน์ (และ) ของ ASCII-art และ skylines ที่สวยงาม!

โปรแกรมของคุณมีเพียงหนึ่งอินพุต: สตริงประกอบด้วยชุด / การซ้ำซ้อนของตัวอักษร0123456789abcใด ๆ

สำหรับแต่ละอักขระอินพุตเอาต์พุตบรรทัดแนวตั้งที่ประกอบดังนี้:

         .
        ..
       ...
      oooo
     ooooo
    OOOOOO
   OOOOOOO
  XXXXXXXX
 XXXXXXXXX
XXXXXXXXXX

0123456789

ตัวอักษรabcแทนตามด้วยหมายเลขหนึ่งและวาดเส้นแนวตั้ง n ตามลำดับที่ 1,2 หรือ 3 หลุม (ช่องว่าง) ที่ด้านล่าง

ตัวอย่าง

อาคารไครสเลอร์

อินพุต: 2479742

   .
   .
  ...
  ooo
  ooo
 OOOOO
 OOOOO
XXXXXXX
XXXXXXX
XXXXXXX

ทัชมาฮาล

อินพุต: 0804023324554233204080

 .                  .
 .                  .
 o                  o
 o        oo        o
 O O     OOOO     O O
 O O  OO OOOO OO  O O
 X X XXXXXXXXXXXX X X
 X X XXXXXXXXXXXX X X
XXXXXXXXXXXXXXXXXXXXXX

หอไอเฟล

อินพุต: 011a2b3b5c9c9b5b3a2110

      ..
      ..
      ..
      oo
     oooo
     OOOO
    OOOOOO
   XXX  XXX
 XXX      XXX
XXX        XXX

คุณสามารถสมมติว่าการป้อนข้อมูลไม่ว่างเปล่าและมีรูปแบบที่ดี
ภาษาใด ๆ ได้รับการยอมรับจากA +เพื่อZ ++

นี่คือรหัสกอล์ฟ: ที่สั้นที่สุดชนะรหัสแหล่งที่มา
หากสิ่งใดในกฎระเบียบไม่ชัดเจนอย่าลังเลที่จะถามความคิดเห็นด้านล่าง

ขอให้สนุกและจับภาพสิ่งก่อสร้างสูงร้อยเมตรในไม่กี่ไบต์!

(และอย่าลืมที่จะรวมอาคารที่คุณชื่นชอบไว้ในโซลูชันของคุณ)

PS: ไม่คุณไม่สามารถดาวน์โหลด / เข้าถึงข้อมูลจากอินเทอร์เน็ตใช้ชื่อไฟล์เป็นข้อมูลและทุกอย่าง มีความยุติธรรมและใช้ทักษะการเล่นกอล์ฟของคุณเท่านั้น


ดูเหมือนจะสูง 9 สำหรับฉัน ... : -
Gabriele D'Antona

โอ้ฉันเข้าใจแล้ว: ด้านบนถูกกำหนดเป็น "c9" นั่นหมายถึง: วาดเส้นแนวตั้งที่มีความสูง 9 และกำจัด 3 ตัวอักษรด้านล่าง นั่นเป็นสาเหตุที่ทำให้คุณดูสูง 7 อ่านกฎอีกครั้งและบอกฉันว่ามันใช้ได้
Gabriele D'Antona

ตกลงฉันเข้าใจผิดสเป็คของคุณของการชดเชย
Howard

คำตอบ:



5

ทับทิม, 88 85

สนุกท้าทาย!

9.downto(0){|h|puts$*[0].gsub(/(\D?)(.)/){'XXXOOoo... '[h<$1.hex-9||$2.hex<h ?-1:h]}}

รับอินพุตบน commandline เช่น:

ruby landscapes.rb 011a2b3b5c9c9b5b3a2110

จะพิมพ์ออกมา:

      ..      
      ..      
      ..      
      oo      
     oooo     
     OOOO     
    OOOOOO    
   XXX  XXX   
 XXX      XXX 
XXX        XXX

5

Python 2.7 - 186

อาจสั้นลงได้ ...

x=[]
l=iter(raw_input())
a="XXX00oo..."
for i in l:
 try:i=int(i);o=0
 except:o=" abc".index(i);i=int(next(l))
 x.append(" "*o+a[o:i+1]+" "*(9-i))
for i in zip(*x)[::-1]:print''.join(i)

วิ่งตัวอย่าง:

08040233245542332040800000247974200000011a2b3b5c9c9b5b3a2110
                             .              ..
 .                  .        .              ..
 .                  .       ...             ..
 o                  o       ooo             oo
 o        oo        o       ooo            oooo
 0 0     0000     0 0      00000           0000
 0 0  00 0000 00  0 0      00000          000000
 X X XXXXXXXXXXXX X X     XXXXXXX        XXX  XXX
 X X XXXXXXXXXXXX X X     XXXXXXX      XXX      XXX
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX        XXX

สะพานซิดนีย์ฮาร์เบอร์

a1a13443a1a2a3a4a5a6a6a7a7a8a8a8a8a9a9a9a9a9a9a8a8a8a8a7a7a6a6a5a4a4a3a2a13443a1a1
                   ......
               ..............
             ..................
           oooooooooooooooooooooo
          oooooooooooooooooooooooo
   00    000000000000000000000000000    00
  0000  00000000000000000000000000000  0000
  XXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXX
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
  XXXX                                 XXXX

สะพานประตูทอง / โลโก้ Cisco

a2a0a0a4a0a06a0a0a4a0a0a2a0a0a4a0a06a0a0a4a0a0a2



      o           o
      o           o
   0  0  0     0  0  0
   0  0  0     0  0  0
X  X  X  X  X  X  X  X  X
X  X  X  X  X  X  X  X  X
      X           X

เป็นคำถามที่ยอดเยี่ยม!


อนุสาวรีย์ที่ยิ่งใหญ่! :)
Gabriele D'Antona

5

C64 พื้นฐาน, 276 ตัวอักษร PETSCII

ทางออกของฉันลงไปที่ 276 ตัวอักษรและพื้นฐาน 10 บรรทัดของ BASIC V2.0!

0inputa$:dIc$(10):fOi=0to9:rE c$(i):nE:fOr=0to9
1z=1
2c=aS(mI(a$,z,z+1))
3ifc>57tHgO8
4ifc>=57-r tH?c$(9-r);:gO6
5?" ";
6z=z+1:ifz<=len(a$)gO2
7?:nE:eN
8z=z+1:w=aS(mI(a$,z,z+1)):ifw>=57-r aNc<=73-r tH?c$(9-r);:gO6
9?" ";:gO6:dA"x","x","x","o","o","W","W",".",".","."

(คัดลอกและวางในอีมูเลเตอร์เพื่อดูผลลัพธ์)

และในที่สุดอนุสาวรีย์ที่ฉันโปรดปรานสะพานบรูคลิน :)

ป้อนคำอธิบายรูปภาพที่นี่


5

C, 130 126 ตัวอักษร

ค่อนข้างนานเมื่อเทียบกับการแข่งขัน แต่ฉันตำหนิภาษา ...

char*p,b[99];r=10,q;main(o){for(gets(&b);r--;puts(""))
for(p=b;q=*p++;)o=q<60?putchar("XXXOOoo... "[o<r&r<q-47?r:10]),-1:q-97;}

ฉันไม่รู้เกี่ยวกับสิ่งปลูกสร้างที่ชื่นชอบแต่หนึ่งในสิ่งที่เป็นที่รู้จักมากขึ้นในบริเวณนี้คือGlobenดังนั้นนี่จึงเป็นการแปลที่แย่

% ./a.out <<<24556667777776665542


       ......       
    oooooooooooo    
  oooooooooooooooo  
 OOOOOOOOOOOOOOOOOO 
 OOOOOOOOOOOOOOOOOO 
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX

คุณสามารถตัดอักขระได้โดยเปลี่ยนลำดับการประกาศเพื่อchar b[99],*p;ให้อ่านchar*p,b[99];ได้ นอกจากนี้อาจใช้เวลาสั้นลงในการputsพิมพ์บรรทัดใหม่
C0deH4cker

@ C0deH4cker ดีขอบคุณ! ที่ช่วยฉันสี่ตัวอักษร
FireFly

@ ฟริออลโอ้ฉันไม่ได้หมายความว่าอย่างนั้นเลยฉันแค่คิดว่าสิ่งที่ฉันคิดว่าเป็นอาคารโปรดของฉัน : P
FireFly

3

APL ( 69 66)

' XXXOOoo...'[1+⌽⍉⌽↑{z×(z<' abc'⍳⍵)<(1+⍎⍺)≥z←⍳10}/↑2↑¨I⊂⍨⎕D∊⍨I←⌽⍞]

ตัวอย่าง:

      'XXXOOoo ... ' [1 + ⌽⍉⌽↑ {z × (z <'abc'⍳⍵) <(1 + ⍎⍺) ≥z←⍳10} / ↑ 2 ↑ ¨I⊂⍨⎕D∊⍨ ฉัน←⌽⍞]
0804023324554233204080

 . .
 . .
 อู 
 oo oo o 
 OO OOOO OO 
 OO OO OOOO OO OO 
 XX XXXXXXXXXXXX XX 
 XX XXXXXXXXXXXX XX 
XXXXXXXXXXXXXXXXXXXXXX

      'XXXOOoo ... ' [1 + ⌽⍉⌽↑ {z × (z <'abc'⍳⍵) <(1 + ⍎⍺) ≥z←⍳10} / ↑ 2 ↑ ¨I⊂⍨⎕D∊⍨ ฉัน←⌽⍞]
011a2b3b5c9c9b5b3a2110
      ..      
      ..      
      ..      
      อู      
     oooo     
     OOOO     
    OOOOOO    
   XXX XXX   
 XXX XXX 
XXX XXX

ฉันไม่รู้จัก APL ดีนัก แต่คุณแน่ใจหรือว่าต้องการช่องว่างในตอนต้นของสตริง 'XXXOOoo ... '
Gabriele D'Antona

@friol: ใช่มันใช้ในการกรอกข้อมูลใน "ว่าง" พื้นที่
marinus



2

PHP ,131 114 ไบต์

for($b=10;$b--;print"
")foreach(str_split($argn)as$a)$c=strpos(' abc',$a)?:!print$a<$b|$b<$c?' ':'XXXOOoo...'[$b];

ลองออนไลน์!

$ echo 2479742|php -nF land.php 
   . 
   . 
  ... 
  ooo 
  ooo 
 OOOOO 
 OOOOO 
XXXXXXX 
XXXXXXX 
XXXXXXX 


$ echo 011a2b3b5c9c9b5b3a2110|php -nF land.php 
      .. 
      .. 
      .. 
      oo 
     oooo 
     OOOO 
    OOOOOO 
   XXX  XXX 
 XXX      XXX 
XXX        XXX 


$ echo a2a0a0a4a0a06a0a0a4a0a0a2a0a0a4a0a06a0a0a4a0a0a2|php -nF land.php 



      o           o 
      o           o 
   O  O  O     O  O  O 
   O  O  O     O  O  O 
X  X  X  X  X  X  X  X  X 
X  X  X  X  X  X  X  X  X 
      X           X


1

05AB1E (ดั้งเดิม) 34 ไบต์

Rvy.ïi"XXXOOoo..."y>£ëðAykÝǝ])ζRí»

ใช้เวอร์ชันดั้งเดิมของ 05AB1E เพื่อบันทึก 2 ไบต์เนื่องจากζทำงานบนสตริงแทนรายการอักขระ

ลองออนไลน์

คำอธิบาย:

R                  # Reverse the (implicit) input-string
 v                 # Loop `y` over each character:
  yi             #  If `y` is a digit:
      "XXXOOoo..." #   Push string "XXXOOoo..."
        y        #   And only leave the first `y`+1 characters as substring
     ë             #  Else (`y` is a letter):
       Ayk         #   Get the index of `y` in the lowercase alphabet
          Ý        #   Create a list in the range [0, alphabet-index]
      ð    ǝ       #   Replace in the string at the top of the stack the characters at
                   #   those indices with a space
 ]                 # Close the if-else statement and loop
  )                # Wrap all strings on the stack into a list
   ζ               # Zip/transpose; swapping rows/columns
    Rí             # Reverse this list, as well as each individual line
      »            # And join the strings by newlines
                   # (after which the result is output implicitly)

สำหรับอาคารโปรดของฉันไปกับต้นไม้ต้นนี้ ;)

b2b3b4b5b6b7898b7b6b5b4b3b2

       .       
      ...      
     .....     
    ooooooo    
   ooooooooo   
  OOOOOOOOOOO  
 OOOOOOOOOOOOO 
XXXXXXXXXXXXXXX
      XXX      
      XXX      

1

Japt -R , 36 ไบต์

óȦnãÒXÌ î"XXXOOoo..."hSpXÎnD)s9Ãz3

ลองมัน

óȦnãÒXÌ î"..."hSpXÎnD)s9Ãz3     :Implicit input of string
ó                                 :Partition at
 È                                :Characters that return true when passed through the following function
  ¦                               :  Test for inequality with
   n                              :  Convert to number
    Ã                             :End function
     £                            :Map each X
      Ò                           :  Bitwise increment
       XÌ                         :  Last character of X
          î                       :  Slice the following to that length
           "..."                  :    Literal string
                h                 :    Replace as many characters as necessary at the start of that string with
                 S                :      Space
                  p               :      Repeat
                   XÎ             :        First character of X
                     n            :        Convert from base
                      D           :        14
                       )          :      End repeat
                        s9        :      Slice off the first 9 characters
                          Ã       :End map
                           z3     :Rotate clockwise by 90 degrees 3 times
                                  :Implicit output, joined by newlines
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.