Comma quibbling - это задача, первоначально заданная Эриком Липпертом в его блоге .
Задача:
Напишите функцию для генерации вывода строки, которая представляет собой конкатенацию входных слов из списка / последовательности, где:
Ввод без слов выводит строку вывода только двух символов скобок «{}». Ввод только одного слова, например ["ABC"], выводит строку вывода слова внутри двух фигурных скобок, например, "{ABC}". Ввод двух слов, например ["ABC", "DEF"], выдает строку вывода двух слов внутри двух фигурных скобок словами, разделенными строкой "и", например "{ABC и DEF}". Ввод трех или более слов, например ["ABC", "DEF", "G", "H"], выводит строку вывода всего, кроме последнего слова, разделенного символом "," с последним словом, разделенным символом "и" «и все в фигурных скобках; например, «{ABC, DEF, G и H}».
Протестируйте свою функцию со следующей серией входов, показывающей ваш вывод здесь, на этой странице:
[] # (Нет входных слов). ["ABC"] ["ABC", "DEF"] ["ABC", "DEF", "G", "H"]
Примечание. Предположим, что для этой задачи слова являются непустыми строками символов верхнего регистра.
Write a function to generate a string output which is the concatenation of input words from a list/sequence where:
"{}"
)["ABC"]
, produces the output string of the word inside the two braces, e.g. "{ABC}"
["ABC", "DEF"]
, produces the output string of the two words inside the two braces with the words separated by the string " and "
, e.g. "{ABC and DEF}"
["ABC", "DEF", "G", "H"]
, produces the output string of all but the last word separated by ", "
with the last word separated by " and "
and all within braces; e.g. "{ABC, DEF, G and H}"
Test your function with the following series of inputs showing your output here on this page:
Note: Assume words are non-empty strings of uppercase characters for this task.