2012-04-28 4 views
0

Это требование: Прочитайте строку и зациклируйте ее, всякий раз, когда встречается новое слово, вставьте его в std :: list. Если. символ имеет пробел, табуляцию, символ новой строки или цифру слева и цифру справа, тогда она рассматривается как десятичная точка и, следовательно, часть слова. В противном случае он рассматривается как полная остановка и разделитель слов.Символ разделителя в строке C++

И это результат я бегу из программы шаблона:

foo.bar -> 2 words (foo, bar) 
f5.5f -> 1 word 
.4.5.6.5 -> 1 word 
d.4.5f -> 3 words (d, 4, 5f) 
.5.6..6.... -> 2 words (.5.6, 6) 

Это кажется очень сложным для меня в первый раз дело со строкой C++. Im действительно застрял в реализации кода. Может ли кто-нибудь предложить мне намек? Благодаря

Я просто сделал некоторые царапины идеи

bool isDecimal(std::string &word) { 
    bool ok = false; 
    for (unsigned int i = 0; i < word.size(); i++) { 
     if (word[i] == '.') { 
      if ((std::isdigit(word[(int)i - 1]) || 
       std::isspace(word[(int)i -1]) || 
       (int)(i - 1) == (int)(word.size() - 1)) && std::isdigit(word[i + 1])) 
       ok = true; 
      else { 
       ok = false; 
       break; 
      } 
     } 
    } 
    return ok; 
} 
    void checkDecimal(std::string &word) { 
    if (!isDecimal(word)) { 
     std::string temp = word; 
     word.clear(); 
     for (unsigned int i = 0; i < temp.size(); i++) { 
      if (temp[i] != '.') 
       word += temp[i]; 
      else { 
       if (std::isalpha(temp[i + 1]) || std::isdigit(temp[i + 1])) 
        word += ' '; 
      } 
     } 
    } 
    trimLeft(word); 
} 
+1

Пожалуйста, покажите нам, что у вас есть. – NPE

+0

Ваши примеры не соответствуют всем требованиям, за исключением строк 1 и 3 – smocking

+0

Это ожидаемый результат из программы шаблонов. – Harry

ответ

0

я предлагаю реализовать его с помощью гибкого и бизон с C++ реализации

+1

Он сказал, что только начинает с C++, и это домашняя работа – smocking

2

Я думаю, что вы, возможно, приближается к проблеме с неверном направлении. Кажется намного легче, если вы перевернете это условие вверх ногами. Чтобы дать вам несколько указателей в псевдокодном скелете:

bool isSeparator(const std::string& string, size_t position) 
{ 
    // Determine whether the character at <position> in <string> is a word separator 
} 

void tokenizeString(const std::string& string, std::list& wordList) 
{ 
    // for every character in string 
     // if(isSeparator(character) || end of string) 
      // list.push_back(substring from last separator to this one) 
} 
Смежные вопросы