4.2 KiB
4.2 KiB
title | id | challengeType | videoUrl | localeTitle |
---|---|---|---|---|
Comma quibbling | 596e414344c3b2872167f0fe | 5 | Запястья |
Description
Comma quibbling - это задача, первоначально заданная Эриком Липпертом в его блоге .
Задача:Напишите функцию для генерации вывода строки, которая представляет собой конкатенацию входных слов из списка / последовательности, где:
Ввод без слов выводит строку вывода только двух символов скобок «{}». Ввод только одного слова, например ["ABC"], выводит строку вывода слова внутри двух фигурных скобок, например, "{ABC}". Ввод двух слов, например ["ABC", "DEF"], выдает строку вывода двух слов внутри двух фигурных скобок словами, разделенными строкой "и", например "{ABC и DEF}". Ввод трех или более слов, например ["ABC", "DEF", "G", "H"], выводит строку вывода всего, кроме последнего слова, разделенного символом "," с последним словом, разделенным символом "и" «и все в фигурных скобках; например, «{ABC, DEF, G и H}».Протестируйте свою функцию со следующей серией входов, показывающей ваш вывод здесь, на этой странице:
[] # (Нет входных слов). ["ABC"] ["ABC", "DEF"] ["ABC", "DEF", "G", "H"]Примечание. Предположим, что для этой задачи слова являются непустыми строками символов верхнего регистра.
Instructions
Tests
tests:
- text: <code>quibble</code> - это функция.
testString: 'assert(typeof quibble === "function", "<code>quibble</code> is a function.");'
- text: '<code>quibble(["ABC"])</code> должен возвращать строку.'
testString: 'assert(typeof quibble(["ABC"]) === "string", "<code>quibble(["ABC"])</code> should return a string.");'
- text: '<code>quibble([])</code> должен возвращать "{}".'
testString: 'assert.equal(quibble(testCases[0]), results[0], "<code>quibble([])</code> should return "{}".");'
- text: '<code>quibble(["ABC"])</code> должен вернуть "{ABC}".'
testString: 'assert.equal(quibble(testCases[1]), results[1], "<code>quibble(["ABC"])</code> should return "{ABC}".");'
- text: '<code>quibble(["ABC", "DEF"])</code> должен возвращать "{ABC и DEF}".'
testString: 'assert.equal(quibble(testCases[2]), results[2], "<code>quibble(["ABC", "DEF"])</code> should return "{ABC and DEF}".");'
- text: '<code>quibble(["ABC", "DEF", "G", "H"])</code> должны возвращать "{ABC, DEF, G и H}".'
testString: 'assert.equal(quibble(testCases[3]), results[3], "<code>quibble(["ABC", "DEF", "G", "H"])</code> should return "{ABC,DEF,G and H}".");'
Challenge Seed
function quibble (words) {
// Good luck!
return true;
}
After Test
console.info('after the test');
Solution
// solution required