106 lines
3.2 KiB
Markdown
106 lines
3.2 KiB
Markdown
![]() |
---
|
|||
|
id: 594810f028c0303b75339ad4
|
|||
|
title: Перенесення слів
|
|||
|
challengeType: 5
|
|||
|
forumTopicId: 302344
|
|||
|
dashedName: word-wrap
|
|||
|
---
|
|||
|
|
|||
|
# --description--
|
|||
|
|
|||
|
Навіть тепер із пропорційними шрифтами та складними макетами, все ще є випадки, коли вам потрібно розмістити текст у вказаний стовпчик. Основним завданням є обернути параграф тексту простим способом.
|
|||
|
|
|||
|
# --instructions--
|
|||
|
|
|||
|
Напишіть функцію, яка може перенести даний текст на будь-яку кількість символів. Як приклад, перенесений текст із 80 символів, має виглядати наступним чином:
|
|||
|
|
|||
|
<pre>
|
|||
|
Перенесіть текст, використовуючи складніший алгоритм, наприклад, алгоритм Кнута і Пласса в системі TeX. Якщо ваша мова надає таку можливість, ви легко отримаєте додаткові бали, але ви
|
|||
|
повинні послатися на документацію, яка вказує, що даний алгоритм є кращим
|
|||
|
ніж простий алгоритм мінімальної довжини.
|
|||
|
</pre>
|
|||
|
|
|||
|
# --hints--
|
|||
|
|
|||
|
перенесення має бути функцією.
|
|||
|
|
|||
|
```js
|
|||
|
assert.equal(typeof wrap, 'function');
|
|||
|
```
|
|||
|
|
|||
|
перенесення має повернути рядок.
|
|||
|
|
|||
|
```js
|
|||
|
assert.equal(typeof wrap('abc', 10), 'string');
|
|||
|
```
|
|||
|
|
|||
|
wrap(80) має повернути 4 рядки.
|
|||
|
|
|||
|
```js
|
|||
|
assert(wrapped80.split('\n').length === 4);
|
|||
|
```
|
|||
|
|
|||
|
Ваша функція `wrap` має повернути наш очікуваний текст.
|
|||
|
|
|||
|
```js
|
|||
|
assert.equal(wrapped80.split('\n')[0], firstRow80);
|
|||
|
```
|
|||
|
|
|||
|
wrap(42) має повернути 7 рядків.
|
|||
|
|
|||
|
```js
|
|||
|
assert(wrapped42.split('\n').length === 7);
|
|||
|
```
|
|||
|
|
|||
|
Ваша функція `wrap` має повернути наш очікуваний текст.
|
|||
|
|
|||
|
```js
|
|||
|
assert.equal(wrapped42.split('\n')[0], firstRow42);
|
|||
|
```
|
|||
|
|
|||
|
# --seed--
|
|||
|
|
|||
|
## --after-user-code--
|
|||
|
|
|||
|
```js
|
|||
|
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--
|
|||
|
|
|||
|
```js
|
|||
|
function wrap(text, limit) {
|
|||
|
return text;
|
|||
|
}
|
|||
|
```
|
|||
|
|
|||
|
# --solutions--
|
|||
|
|
|||
|
```js
|
|||
|
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;
|
|||
|
}
|
|||
|
```
|