Anda harus membuat buku!

15

Anda bekerja di mesin cetak virtual, kuno. Untuk membantu Anda mengatur surat monospace Anda lebih cepat, Anda memutuskan untuk membuat program sesingkat mungkin untuk membantu Anda. Diberikan string teks dan ukuran halaman, hasilkan dan output setiap halaman teks.

Contohnya

Misalnya, dengan lebar halaman 14, tinggi 7, dan beberapa teks, inilah buku Anda:

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.   |
|            |
+------------+

Berikut pengaturan halaman dasar:

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

Beberapa hal

  1. Ada margin satu ruang antara tepi halaman dan teks.
  2. Lebar dan tinggi termasuk tepi kotak, jika itu tidak jelas.
  3. Sampul hanya terjadi jika sebuah kata tidak dapat ditampung dalam satu baris.
  4. Program harus mampu menghasilkan halaman sebanyak yang dibutuhkan, dan hanya sebanyak itu saja.
  5. Program Anda harus mendukung ukuran halaman apa pun, bukan hanya 14 kali 7.
  6. Ini adalah kode golf, jadi solusi terkecil dalam byte (bahasa apa pun) menang.
  7. Jangan merusak kesenangannya. Lubang standar jelas tidak diizinkan.

Oh, dan, omong-omong:

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

+------------+
| Best       |
| program    |
| so far:    | 
| Charcoal   |
|            |
+------------+
saya..
sumber
@rod Ups, sudah diperbaiki.
saya ..
7
Jika maksud Anda for example 14itue.g.
FrownyFrog
Erat terkait.
Martin Ender
4
Apakah kita perlu menangani 'multi-pemotongan' pada satu kata? (seperti scru-/-mpt-/-ious)
Arnauld
1
@Arnauld Jika sebuah kata cukup panjang, maka ya.
saya ..

Jawaban:

5

Python 2 , 306 304 283 279 byte

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])

Cobalah online!

TFeld
sumber
Saya pikir Anda dapat menggunakan L=lenuntuk menyimpan total 2 byte ...
Chas Brown
FYI (tidak yakin apakah perlu diatasi) test case yang saya sarankan ( 7, 3, "Three Is The Magic Number!") menghasilkan halaman kosong terkemuka.
Jonathan Allan
1
@JonathanAllan Terima kasih, perbaiki :)
TFeld
3

Arang , 105 83 byte

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

Cobalah online! Tautan adalah untuk menyatakan versi kode yang tidak dapat ditangani oleh deverbosifier dan operator nilary . Jika memimpin baris kosong dapat diterima, saya bisa turun ke 76 byte:

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

Penjelasan:

NθNη

Masukkan lebar qdan tinggi ke dalam h.

M⁺η²↑

Pindah ke posisi yang akan memicu kotak pertama untuk ditarik, tetapi tanpa menghasilkan margin atas.

F⪪S «

Lingkari semua kata dalam string input.

W›Lι⁻θ⁴«

Ulangi saat kata terlalu lebar untuk dimasukkan ke dalam kotak.

⊞υ⁺…ι⁻θ⁵-

Dorong sebanyak mungkin kata yang cocok dengan tanda hubung tambahan.

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

Awali tanda hubung ke seluruh kata.

⊞υι»

Tekan sisa kata.

Fυ«

Lingkari semua kata yang ditulis dengan tanda penghubung.

¿‹Lι±ⅈ

Periksa apakah kata tersebut sesuai dengan baris saat ini.

 «

Jika demikian maka cetak spasi.

M⁻⁻⁴ⅈθ¹

Kalau tidak, pindah ke awal baris berikutnya.

¿¬﹪ⅉ⊕η

Periksa apakah kami membutuhkan kotak baru.

«↙↙Bθη↘→»»

Jika demikian maka gambarlah kotak itu.

ι

Akhirnya, cetak kata.

Neil
sumber
2

Perl 5 , 203 182 +1 ( -a) = 183 byte

$t=($\=-3+shift@F)-2;$h=shift@F}{say$_='+'.'-'x$\.'-+';map{$_="";{$_.=shift@F;s/.{$t}\K..+/-/&&unshift@F,-$&;$_.=$";y///c+length$F[0]<$\&&redo}printf"| %-$\s|
",$_}3..$h;say;@F&&redo

Cobalah online!

Xcali
sumber
2

SOGL V0.12 , 92 byte

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

Coba Di Sini!

dzaima
sumber
Gagal dengan lebar bawah
Jonathan Allan
@ Jonathan Allan oh. : / memperbaiki ini untuk memungkinkan multi-pemotongan mungkin akan menjadi banyak byte ..
dzaima
2

JavaScript (ES8), 242 byte

Terima kasih kepada @ Tvde1 untuk melaporkan bug

(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)

Cobalah online!

Berkomentar

(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
Arnauld
sumber
Coba contoh teks Anda dengan 12dan 7, beberapa baris / kata dibalik.
Tvde1
1
@ Tvde1 Terima kasih telah melaporkan ini. Sekarang harus diperbaiki .
Arnauld
1

Jelly , 93 byte

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

Sebuah program penuh mengambil tiga argumen ( text, width, height) yang mencetak halaman.

Cobalah online! NB Terlalu tidak efisien untuk menjalankan contoh dari OP dalam batas 60 detik.

( 97 byte jika baris kosong antara halaman sebenarnya merupakan persyaratan)

Bagaimana?

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
Jonathan Allan
sumber
0

PHP, 299 byte

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,"-")."+
";

Jalankan dengan php -nr '<code>' <width> <height> '<text>'atau atau coba online .

Titus
sumber