freeCodeCamp/curriculum/challenges/italian/10-coding-interview-prep/rosetta-code/word-wrap.md

2.5 KiB

id title challengeType forumTopicId dashedName
594810f028c0303b75339ad4 Mandare a capo 5 302344 word-wrap

--description--

Ancora oggi, con caratteri proporzionali e layout complessi, ci sono ancora casi in cui è necessario mandare a capo il testo in una colonna specificata. Il compito di base è quello di chiudere un paragrafo di testo in modo semplice.

--instructions--

Scrivi una funzione che può mandare a capo questo testo a qualsiasi numero di caratteri. Ad esempio, il testo a capo di 80 caratteri dovrebbe assomigliare a quanto segue:

Wrap text using a more sophisticated algorithm such as the Knuth and Plass TeX
algorithm. If your language provides this, you get easy extra credit, but you
must reference documentation indicating that the algorithm is something better
than a simple minimum length algorithm.

--hints--

wrap dovrebbe essere una funzione.

assert.equal(typeof wrap, 'function');

wrap dovrebbe restituire una stringa.

assert.equal(typeof wrap('abc', 10), 'string');

wrap(80) dovrebbe restituire 4 righe.

assert(wrapped80.split('\n').length === 4);

La funzione wrap dovrebbe restituire il testo previsto.

assert.equal(wrapped80.split('\n')[0], firstRow80);

wrap(42) dovrebbe restituire 7 righe.

assert(wrapped42.split('\n').length === 7);

La funzione wrap dovrebbe restituire il testo previsto.

assert.equal(wrapped42.split('\n')[0], firstRow42);

--seed--

--after-user-code--

const text =
`Wrap text using a more sophisticated algorithm such as the Knuth and Plass TeX algorithm.
If your language provides this, you get easy extra credit,
but you ''must reference documentation'' indicating that the algorithm
is something better than a simple minimum length algorithm.`;

const wrapped80 = wrap(text, 80);
const wrapped42 = wrap(text, 42);

const firstRow80 =
    'Wrap text using a more sophisticated algorithm such as the Knuth and Plass TeX';

const firstRow42 = 'Wrap text using a more sophisticated';

--seed-contents--

function wrap(text, limit) {
  return text;
}

--solutions--

function wrap(text, limit) {
  const noNewlines = text.replace('\n', '');
  if (noNewlines.length > limit) {
    // find the last space within limit
    const edge = noNewlines.slice(0, limit).lastIndexOf(' ');
    if (edge > 0) {
      const line = noNewlines.slice(0, edge);
      const remainder = noNewlines.slice(edge + 1);
      return line + '\n' + wrap(remainder, limit);
    }
  }
  return text;
}