190 lines
7.6 KiB
Markdown
190 lines
7.6 KiB
Markdown
---
|
||
id: 594810f028c0303b75339ad0
|
||
title: Вирівнювання стовпців
|
||
challengeType: 5
|
||
forumTopicId: 302224
|
||
dashedName: align-columns
|
||
---
|
||
|
||
# --description--
|
||
|
||
Дано масив з багатьма рядками, де поля в рядку зображені одним символом `$`, напишіть програму, яка вирівнює кожен стовпець полів, переконавшись, що слова в кожному стовпці розділені принаймні одним пробілом. Крім того, дозвольте кожному слову у стовпці вирівнюватись ліворуч, праворуч або вирівнюватись по центру стовпця.
|
||
|
||
# --instructions--
|
||
|
||
Щоб перевірити свої програми, використовуйте наступний текст:
|
||
|
||
```js
|
||
const testText = [
|
||
'Given$a$text$file$of$many$lines',
|
||
'where$fields$within$a$line$',
|
||
'are$delineated$by$a$single$"dollar"$character',
|
||
'write$a$program',
|
||
'that$aligns$each$column$of$fields',
|
||
'by$ensuring$that$words$in$each$',
|
||
'column$are$separated$by$at$least$one$space.',
|
||
'Further,$allow$for$each$word$in$a$column$to$be$either$left$',
|
||
'justified,$right$justified',
|
||
'or$center$justified$within$its$column.'
|
||
];
|
||
```
|
||
|
||
**Зауважте, що:**
|
||
|
||
- Приклади рядків текстів для введення можуть у кінці мати символ долара.
|
||
- Усі стовпці повинні мати однакове вирівнювання.
|
||
- Декілька послідовно розміщених символів пробілу у кінці рядків, є неважливими для цілей завдання.
|
||
- Вихідний текст буде відображатися моношироким шрифтом у звичайному текстовому редакторі або базовому терміналі. Рядки в ньому слід з'єднати, використовуючи новий символ рядка (`\n`).
|
||
- Мінімальний простір між стовпцями слід обчислювати з даного тексту, а не жорстко його кодувати.
|
||
- Не обов'язково додавати розділові символи між стовпцями або навколо них.
|
||
|
||
Наприклад, один з рядків взятий із `testText`, після вирівнювання праворуч, ліворуч та посередині відповідно:
|
||
|
||
```js
|
||
' column are separated by at least one space.\n'
|
||
'column are separated by at least one space.\n'
|
||
' column are separated by at least one space.\n'
|
||
```
|
||
|
||
# --hints--
|
||
|
||
`formatText` має бути функцією.
|
||
|
||
```js
|
||
assert(typeof formatText === 'function');
|
||
```
|
||
|
||
`formatText(testText, 'right')` має створити стовпець із текстом, який буде вирівняний по правій стороні.
|
||
|
||
```js
|
||
assert.strictEqual(formatText(_testText, 'right'), rightAligned);
|
||
```
|
||
|
||
`formatText(testText, 'left')` має створити стовпець із текстом, який буде вирівняний по лівій стороні.
|
||
|
||
```js
|
||
assert.strictEqual(formatText(_testText, 'left'), leftAligned);
|
||
```
|
||
|
||
`formatText(testText, 'center')` має створити стовпець із текстом, який буде вирівняний по центру.
|
||
|
||
```js
|
||
assert.strictEqual(formatText(_testText, 'center'), centerAligned);
|
||
```
|
||
|
||
# --seed--
|
||
|
||
## --after-user-code--
|
||
|
||
```js
|
||
const _testText = [
|
||
'Given$a$text$file$of$many$lines',
|
||
'where$fields$within$a$line$',
|
||
'are$delineated$by$a$single$"dollar"$character',
|
||
'write$a$program',
|
||
'that$aligns$each$column$of$fields$',
|
||
'by$ensuring$that$words$in$each$',
|
||
'column$are$separated$by$at$least$one$space.',
|
||
'Further,$allow$for$each$word$in$a$column$to$be$either$left$',
|
||
'justified,$right$justified',
|
||
'or$center$justified$within$its$column.'
|
||
];
|
||
|
||
const rightAligned = ' Given a text file of many lines\n' +
|
||
' where fields within a line \n' +
|
||
' are delineated by a single "dollar" character\n' +
|
||
' write a program\n' +
|
||
' that aligns each column of fields \n' +
|
||
' by ensuring that words in each \n' +
|
||
' column are separated by at least one space.\n' +
|
||
' Further, allow for each word in a column to be either left \n' +
|
||
'justified, right justified\n' +
|
||
' or center justified within its column.';
|
||
|
||
const leftAligned = 'Given a text file of many lines \n' +
|
||
'where fields within a line \n' +
|
||
'are delineated by a single "dollar" character\n' +
|
||
'write a program \n' +
|
||
'that aligns each column of fields \n' +
|
||
'by ensuring that words in each \n' +
|
||
'column are separated by at least one space.\n' +
|
||
'Further, allow for each word in a column to be either left \n' +
|
||
'justified, right justified\n' +
|
||
'or center justified within its column. ';
|
||
|
||
const centerAligned = ' Given a text file of many lines \n' +
|
||
' where fields within a line \n' +
|
||
' are delineated by a single \"dollar\" character\n' +
|
||
' write a program \n' +
|
||
' that aligns each column of fields \n' +
|
||
' by ensuring that words in each \n' +
|
||
' column are separated by at least one space.\n' +
|
||
' Further, allow for each word in a column to be either left \n' +
|
||
'justified, right justified\n' +
|
||
' or center justified within its column. ';
|
||
```
|
||
|
||
## --seed-contents--
|
||
|
||
```js
|
||
function formatText(input, justification) {
|
||
|
||
}
|
||
|
||
const testText = [
|
||
'Given$a$text$file$of$many$lines',
|
||
'where$fields$within$a$line$',
|
||
'are$delineated$by$a$single$"dollar"$character',
|
||
'write$a$program',
|
||
'that$aligns$each$column$of$fields$',
|
||
'by$ensuring$that$words$in$each$',
|
||
'column$are$separated$by$at$least$one$space.',
|
||
'Further,$allow$for$each$word$in$a$column$to$be$either$left$',
|
||
'justified,$right$justified',
|
||
'or$center$justified$within$its$column.'
|
||
];
|
||
```
|
||
|
||
# --solutions--
|
||
|
||
```js
|
||
String.prototype.repeat = function (n) { return new Array(1 + parseInt(n)).join(this); };
|
||
|
||
function formatText(input, justification) {
|
||
let x, y, max, cols = 0, diff, left, right;
|
||
for (x = 0; x < input.length; x++) {
|
||
input[x] = input[x].split('$');
|
||
if (input[x].length > cols) {
|
||
cols = input[x].length;
|
||
}
|
||
}
|
||
for (x = 0; x < cols; x++) {
|
||
max = 0;
|
||
for (y = 0; y < input.length; y++) {
|
||
if (input[y][x] && max < input[y][x].length) {
|
||
max = input[y][x].length;
|
||
}
|
||
}
|
||
for (y = 0; y < input.length; y++) {
|
||
if (input[y][x]) {
|
||
diff = (max - input[y][x].length) / 2;
|
||
left = ' '.repeat(Math.floor(diff));
|
||
right = ' '.repeat(Math.ceil(diff));
|
||
if (justification === 'left') {
|
||
right += left; left = '';
|
||
}
|
||
if (justification === 'right') {
|
||
left += right; right = '';
|
||
}
|
||
input[y][x] = left + input[y][x] + right;
|
||
}
|
||
}
|
||
}
|
||
for (x = 0; x < input.length; x++) {
|
||
input[x] = input[x].join(' ');
|
||
}
|
||
input = input.join('\n');
|
||
return input;
|
||
}
|
||
```
|