คุณมีหนังสือที่จะทำ!


15

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

ตัวอย่าง

ตัวอย่างเช่นด้วยความกว้างของหน้า 14 ความสูง 7 และข้อความบางส่วนนี่คือหนังสือของคุณ:

14, 7, "Fruits make an extremely good snack due to their utterly scrumptious sweetness. They are also very healthy for you."
+------------+
| Fruits     |
| make an    |
| extremely  |
| good snack |
| due to     |
+------------+

+------------+
| their      |
| utterly    |
| scrumptio- |
| -us        |
| sweetness. |
+------------+

+------------+
| They are   |
| also very  |
| healthy    |
| for you.   |
|            |
+------------+

นี่คือการตั้งค่าหน้าพื้นฐาน:

|---i.e.14---|
+------------+ - 
| Xxxxxxxxxx | |
| Xxxxxxxxxx | i.  
| Xxxxxxxxxx | e. 
| Xxxxxxxxxx | 7
| Xxxxxxxxxx | | 
+------------+ - 

บางสิ่ง

  1. มีระยะห่างหนึ่งช่องว่างระหว่างขอบหน้าและข้อความ
  2. ความกว้างและความสูงรวมถึงขอบของกล่องถ้าไม่ชัดเจน
  3. การขึ้นบรรทัดใหม่จะเกิดขึ้นหากคำไม่สามารถอยู่ในบรรทัดเดียวได้
  4. โปรแกรมจะต้องสามารถส่งออกเป็นหน้าได้มากเท่าที่ต้องการและมีเพียงจำนวนมาก
  5. โปรแกรมของคุณต้องรองรับขนาดหน้ากระดาษใด ๆ ไม่ใช่แค่ขนาด 14 คูณ 7
  6. นี่คือโค้ดกอล์ฟดังนั้นทางออกที่เล็กที่สุดเป็นไบต์ (ทุกภาษา) ชนะ
  7. อย่าทำลายความสนุก ไม่อนุญาตให้มีช่องโหว่มาตรฐาน

โอ้และโดยวิธี:

+------------+
| May the    |
| best book  |
| publisher  | 
| win. Good  |
| Luck!      |
+------------+

+------------+
| Best       |
| program    |
| so far:    | 
| Charcoal   |
|            |
+------------+

@ อ๊ะโอ๊ะโอแก้ไขแล้ว
ฉัน ..

7
ถ้าคุณหมายถึงfor example 14นั่นe.g.
FrownyFrog


4
เราจำเป็นต้องจัดการ 'multi-cut' ด้วยคำเดียวหรือไม่? (เช่นscru-/-mpt-/-ious)
Arnauld

1
@Annauld ถ้าคำยาวพอใช่แล้ว
ฉัน ..

คำตอบ:


5

Python 2 , 306 304 283 279 ไบต์

def f(w,h,s):
 b=[];w-=4;h-=2;H='+-'+'-'*w+'-+';x=l='';s=s.split()
 while s:
	W=s.pop(0)
	if W[w:]:W,s=W[:w-1]+'-',['-'+W[w-1:]]+s
	if len(l+W)<=w-(l>x):l+=' '*(l>x)+W
	else:b+=[l];l=W
 b+=[l]+[x]*h
 while any(b):print'\n'.join([H]+['| %-*s |'%(w,b.pop(0))for _ in' '*h]+[H,x,x])

ลองออนไลน์!


ฉันคิดว่าคุณสามารถใช้L=lenเพื่อประหยัด 2 ไบต์รวม ...
Chas บราวน์

FYI (ไม่แน่ใจว่าต้องระบุที่อยู่หรือไม่) กรณีทดสอบที่ฉันแนะนำ ( 7, 3, "Three Is The Magic Number!") ให้หน้าว่างชั้นนำ
Jonathan Allan

1
@JanathanAllan ขอบคุณแก้ไขมัน :)
TFeld

3

ถ่าน , 105 83 ไบต์

NθNηM⁺η²↑F⪪S «W›Lι⁻θ⁴«⊞υ⁺…ι⁻θ⁵-≔⁺-✂ι⁻θ⁵Lι¹ι»⊞υι»Fυ«¿‹Lι±ⅈ «M⁻⁻⁴ⅈθ¹¿¬﹪ⅉ⊕η«↙↙Bθη↘→»»ι

ลองออนไลน์! Link เป็นไปอย่างละเอียดรุ่นของรหัสdeverbosifier ไม่สามารถจัดการและnilary ผู้ประกอบการ หากบรรทัดว่างนำหน้าเป็นที่ยอมรับฉันสามารถลดขนาดได้ถึง 76 ไบต์:

≔⁻N⁴θMθ→NηF⪪S «W›Lιθ«⊞υ⁺…ι⊖θ-≔⁺-✂ι⊖θLι¹ι»⊞υι»Fυ«¿‹⁺ⅈLιθ «F¬﹪ⅉ⊕η«⸿↙↙B⁺θ⁴η»⸿»ι

คำอธิบาย:

NθNη

การป้อนข้อมูลความกว้างลงไปและความสูงเข้าไปในqh

M⁺η²↑

ย้ายไปยังตำแหน่งที่จะทริกเกอร์กล่องแรกที่จะวาด แต่ไม่มีการสร้างระยะขอบด้านบน

F⪪S «

วนรอบคำทั้งหมดในสตริงอินพุต

W›Lι⁻θ⁴«

ทำซ้ำในขณะที่คำกว้างเกินไปที่จะใส่ลงในกล่อง

⊞υ⁺…ι⁻θ⁵-

ดันคำให้มากพอที่จะใส่เครื่องหมายยัติภังค์ต่อท้าย

≔⁺-✂ι⁻θ⁵Lι¹ι»

คำนำหน้าเครื่องหมายขีดคั่นกับส่วนที่เหลือของคำ

⊞υι»

ดันคำที่เหลือ

Fυ«

วนรอบคำที่ใส่ยัติภังค์ทั้งหมด

¿‹Lι±ⅈ

ตรวจสอบว่าคำที่เหมาะกับบรรทัดปัจจุบัน

 «

ถ้าเป็นเช่นนั้นให้พิมพ์ช่องว่าง

M⁻⁻⁴ⅈθ¹

มิฉะนั้นย้ายไปที่จุดเริ่มต้นของบรรทัดถัดไป

¿¬﹪ⅉ⊕η

ตรวจสอบว่าเราต้องการกล่องใหม่หรือไม่

«↙↙Bθη↘→»»

ถ้าเป็นเช่นนั้นแล้ววาดกล่อง

ι

ในที่สุดพิมพ์คำว่า



2

SOGL V0.12 , 92 ไบต์

Aē:b⁾\&?Q¶oQ}cI@*¼|a31žO■
.⁾:0EHC┌*¼+Q,θK;{⁴D@Κ+lc<‽Xd■Flc<‽ø;c⁾{Kh+;}D┌+■d┌Κ}}}■beb⁾%-⁾{ø■}

ลองที่นี่!



@JanathanAllan โอ้ : / แก้ไขสิ่งนี้เพื่ออนุญาตให้มีการตัดหลายครั้งอาจจะเป็นจำนวนมาก ..
dzaima

2

JavaScript (ES8), 242 ไบต์

ขอบคุณ @ Tvde1 สำหรับการรายงานข้อผิดพลาด

(s,w,h)=>s.split` `.map(g=s=>l=(l+s)[W=w-5]?s[l&&A(l),l='',w-4]?g('-'+s.slice(W),A(s.slice(0,W)+'-')):s:l?l+' '+s:s,n=o=l='',h-=2,b=`+${'-'.repeat(w-2)}+
`,A=s=>o+=(!n|n++%h?'':b+`
`+b)+`| ${s.padEnd(w-3)}|
`)&&(g=s=>A(s)&&n%h?g(''):b+o+b)(l)

ลองออนไลน์!

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

(s, w, h) =>                        // given s = string, w = width, h = height
  s.split` `                        // get all words by splitting the string on spaces
  .map(g = s =>                     // for each word s:
    l = (l + s)[W = w - 5] ?        //   if the word is too long for the current line:
      s[ l && A(l),                 //     append the line (if not empty)
         l = '',                    //     clear the line
         w - 4 ] ?                  //     if the word itself doesn't fit:
        g(                          //       do a recursive call with:
          '-' + s.slice(W),         //         a hyphen + the next part
          A(s.slice(0, W) + '-')    //         and append the current part + a hyphen
        )                           //       end of recursive call
      :                             //     else:
        s                           //       initialize a new line with this word
    :                               //   else:
      l ?                           //     if the current line is not empty:
        l + ' ' + s                 //       append a space + the word
      :                             //     else:
        s,                          //       initialize a new line with this word
    n = o = l = '',                 //   n = line counter, o = output, l = line
    h -= 2,                         //   adjust h
    b = `+${'-'.repeat(w - 2)}+\n`, //   b = border + linefeed
    A = s =>                        //   A = function that updates the output o:
      o += (                        //     append to o:
        !n | n++ % h ?              //       if we haven't reached an end of page:
          ''                        //         an empty string
        :                           //       else:
          b + `\n` + b              //         bottom border + linefeed + top border
      ) +                           //       followed by
      `| ${s.padEnd(w - 3)}|\n`     //       left border + padded text + right border
  ) &&                              // end of map()
  (g = s =>                         // g = recursive function taking s:
    A(s) &&                         //   append s
    n % h ?                         //   if we haven't reached an end of page:
      g('')                         //     go on with an empty line
    :                               //   else:
      b + o + b                     //     return top border + output + bottom border
  )(l)                              // initial call to g() with the last pending line

ลองตัวอย่างข้อความของคุณด้วย12และ7บางบรรทัด / คำถูกย้อนกลับ
Tvde1

1
@ Tvde1 ขอบคุณที่รายงานสิ่งนี้ ตอนนี้มันควรจะได้รับการแก้ไข
Arnauld

1

เยลลี่ , 93 ไบต์

1,⁴Ṭị⁾+-W,`
ṣ⁶µḊṖs⁴_6¤j⁾--;@Ḣ;Ṫḟ0s⁴_©4¤µ€ẎŒṖK€€µL€>®ẸµÐḟṪ;€⁶x®¤ḣ€®s⁵_2¤Zz⁶x®¤j@€€⁾| ,U¤j@€¢ẎY

โปรแกรมการเต็มรูปแบบสามข้อโต้แย้ง ( text, width, height) ซึ่งพิมพ์หน้าเว็บ

ลองออนไลน์! NB ไม่มีประสิทธิภาพในการรันตัวอย่างจาก OP ภายในระยะเวลา 60 วินาที

( 97 ไบต์)หากบรรทัดว่างระหว่างหน้าเป็นข้อกำหนดจริง)

อย่างไร?

1,⁴Ṭị⁾+-W,` - Link 1, make header & footer: no arguments
  ⁴         - program's 2nd argument, width
1           - literal one
 ,          - pair = [1,width]
   Ṭ        - untruth = [1,0,0,...,0,0,1] (a 1 at index 1 and index width; 0 elsewhere)
     ⁾+-    - literal list of characters = "+-"
    ị       - index into (1-based & modular) = "+--...--+"
        W   - wrap = ["+---...--+']
          ` - use as both arguments of the dyad:
         ,  - pair = [["+---...--+'],["+---...--+']]

ṣ⁶µḊṖs⁴_6¤j⁾--;@Ḣ;Ṫḟ0s⁴_©4¤µ€ẎŒṖK€€µL€>®ẸµÐḟṪ;€⁶x®¤ḣ€®s⁵_2¤Zz⁶x®¤j@€€⁾| ,U¤j@€¢ẎY

 - Main link. This is long so splitting it up into parts like so:
ṣ⁶µ "A" µ€ "B" µ "C" µÐḟ "D"
ṣ⁶                           - split 1st argument (text) at spaces
  µ "A" µ€                   - for €ach resulting word do "A" (get hyphenated parts)
           "B"               - do "B" (all ways to partition those joining with spaces)
                     µÐḟ     - filter discard if:
               µ "C"         -   do "C" (any parts are too long)
                         "D" - do "D" (format the resulting list into the page-format)

"A" = ḊṖs⁴_6¤j⁾--;@Ḣ;Ṫḟ0s⁴_©4¤ - Hyphenate: list, word     e.g. "Something"
      Ḋ                        - dequeue                        "omething"
       Ṗ                       - pop                            "omethin"
            ¤                  - nilad followed by link(s) as a nilad
         ⁴                     -   program's 2nd argument  e.g. 9  (width)
           6                   -   literal six                  6
          _                    -   subtract                     3
        s                      - split into chunks             ["ome","thi","n"]
              ⁾--              - literal list of characters     "--"
             j                 - join                           "ome--thi--n"
                   Ḣ           - head (word)                    "S"
                 ;@            - concatenate (sw@p arguments)   "Some--thi--n"
                     Ṫ         - tail (word)                    "g"
                    ;          - concatenate                    "Some--thi--ng"
                      ḟ0       - filter out zeros (tail yields 0 for words of length 1)
                             ¤  - nilad followed by link(s) as a nilad:
                         ⁴      -   program's 2nd argument      9
                            4   -   literal four                4
                          _     -   subtract                    5
                           ©    -   copy to register & yield    5
                        s       - split into chunks             ["Some-","-thi-","-ng"]

"B" = ẎŒṖK€€ - Line arrangements: list of lists of hyphen-parts / single words
      Ẏ      - flatten by one (make a list of words and hyphen-parts
             - e.g. [["Not"],["hyph-","-ena-","-ted"]] -> ["Not","hyph-","-ena-","-ted"]
       ŒṖ    - partition e.g. [1,2,3]->[[[1],[2],[3]],[[1],[2,3]],[[1,2],[3]],[[1,2,3]]]
         K€€ - join with spaces for €ach for €ach e.g. ["one","two"]->"one two"

"C" = L€>®Ẹ - Any part too long?: one of the list of lines from "B"
      L€    - length of €ach
         ®  - recall from the register (width minus 4)
        >   - greater than (vectorises) - 1 if so 0 if not
          Ẹ - any truthy? (1 if any too long)

"D" = Ṫ;€⁶x®¤ḣ€®s⁵_2¤Zz⁶x®¤j@€€⁾| ,U¤j@€¢ẎY - Format as pages: list of valid arrangements
      Ṫ                                     - tail (last valid partition is greediest)
            ¤                               - nilad followed by links as a nilad:
         ⁶                                  -   literal space character
           ®                                -   recall from register (width minus 4)
          x                                 -   repeat elements
       ;€                                   - concatenate to €ach
               ®                            - recall from register (width minus 4)
             ḣ€                             - head €ach to index
                    ¤                       - nilad followed by links as a nilad:
                 ⁵                          -   program's 3rd argument, height
                   2                        -   literal two
                  _                         -   subtract
                     Z                      - transpose
                          ¤                 - nilad followed by link(s) as a nilad:

                       ⁶                    -   literal space character
                         ®                  -   recall from register (width minus 4)
                        x                   -   repeat elements

                      z                     - transpose with filler (repeated spaces)
                                    ¤       - nilad followed by link(s) as a nilad:
                               ⁾|<space>    -   literal list of characters = "| "
                                   U        -   upend = " |"
                                  ,         -   pair = ["| "," |"]
                           j@€€             - join for €ach for €ach (sw@p arguments)
                                        ¢   - call last link (1) as a nilad
                                     j@€    - join for €ach (sw@p arguments)
                                         Ẏ  - flatten by one
                                          Y - join with line feeds
                                            - implicit print

0

PHP, 299 ไบต์

for($a=explode(" ",$argv[3]);$y|$e=strlen($d=$a[+$i++]);$x||print"|",$x|$e<$w?$e<$w-$x?$x+=$e+print" $d":$i-=!$x=!$y+=print str_pad("",$w-$x)." |
":$y+=print" ".substr($d,0,$w-2)."- |
".!$a[--$i]="-".substr($d,$w-2),$y>$argv[2]-2&&$y=!print"$t
")$y||$y=print$t=str_pad("+",2+$w=$argv[1]-3,"-")."+
";

ทำงานด้วยphp -nr '<code>' <width> <height> '<text>'หรือหรือลองออนไลน์

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