Вы даже можете решить это с помощью одной строки (хотя и немного некрасиво):
String.Join(String.Empty, input.Split('-').Select(q => (q.Length == 0 ? String.Empty : (q.Length > 1 ? (q.First() + q.Last()).ToString() : q.First().ToString())))).Substring(((input[0] + input[1]).ToString().Contains('-') ? 0 : 1), input.Length - ((input[0] + input[1]).ToString().Contains('-') ? 0 : 1) - ((input[input.Length - 1] + input[input.Length - 2]).ToString().Contains('-') ? 0 : 1));
сначала он разбивает строку на массив на каждом '-'
, затем объединяет только первый и последний символ каждой строки (или только единственный символ, если есть только один, и оставляет пустую строку, если ничего нет там), а затем он объединяет полученное перечисление в строку. Наконец, мы удаляем первую и последнюю букву, если они не находятся в нужном диапазоне.
Я знаю, это уродливо, я просто говорю, что это возможно ..
Возможно, лучше просто использовать простое
new Regex(@"\w(?=-)|(?<=-)\w", RegexOptions.Compiled)
, а затем работать с этим ..
РЕДАКТИРОВАТЬ @ Кирилл Полищук был быстрее .. его решение должно работать ..
РЕДАКТИРОВАТЬ 2
После того, как Вопрос был обновлен, вот фрагмент кода, который должен помочь:
string input = "A-B-C";
string s2;
string s3 = "";
string s4 = "";
var splitted = input.Split('-');
foreach(string s in splitted) {
if (s.Length == 0)
s2 = String.Empty;
else
if (s.Length > 1)
s2 = (s.First() + s.Last()).ToString();
else
s2 = s.First().ToString();
s3 += s4 + s2;
s4 = " and ";
}
int beginning;
int end;
if (input.Length > 1)
{
if ((input[0] + input[1]).ToString().Contains('-'))
beginning = 0;
else
beginning = 1;
if ((input[input.Length - 1] + input[input.Length - 2]).ToString().Contains('-'))
end = 0;
else
end = 1;
}
else
{
if ((input[0]).ToString().Contains('-'))
beginning = 0;
else
beginning = 1;
if ((input[input.Length - 1]).ToString().Contains('-'))
end = 0;
else
end = 1;
}
string result = s3.Substring(beginning, s3.Length - beginning - end);
Это не очень элегантно, но должно работать (не проверено, хотя ..). он работает почти так же, как вышеописанный однострочный ...