freeCodeCamp/curriculum/challenges/russian/08-coding-interview-prep/rosetta-code/comma-quibbling.russian.md

4.2 KiB
Raw Blame History

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([&quot;ABC&quot;])</code> должен возвращать строку.'
    testString: 'assert(typeof quibble(["ABC"]) === "string", "<code>quibble(["ABC"])</code> should return a string.");'
  - text: '<code>quibble([])</code> должен возвращать &quot;{}&quot;.'
    testString: 'assert.equal(quibble(testCases[0]), results[0], "<code>quibble([])</code> should return "{}".");'
  - text: '<code>quibble([&quot;ABC&quot;])</code> должен вернуть &quot;{ABC}&quot;.'
    testString: 'assert.equal(quibble(testCases[1]), results[1], "<code>quibble(["ABC"])</code> should return "{ABC}".");'
  - text: '<code>quibble([&quot;ABC&quot;, &quot;DEF&quot;])</code> должен возвращать &quot;{ABC и DEF}&quot;.'
    testString: 'assert.equal(quibble(testCases[2]), results[2], "<code>quibble(["ABC", "DEF"])</code> should return "{ABC and DEF}".");'
  - text: '<code>quibble([&quot;ABC&quot;, &quot;DEF&quot;, &quot;G&quot;, &quot;H&quot;])</code> должны возвращать &quot;{ABC, DEF, G и H}&quot;.'
    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