Исправить / улучшить функцию переноса слов - PullRequest
0 голосов
/ 28 апреля 2011

У меня есть простая функция переноса слов, которая принимает длинную строку в качестве входных данных, а затем разбивает эту строку на меньшие строки и добавляет их в массив для вывода позже.Сейчас последнее слово или два не выводятся.Это главная проблема.Тем не менее, я также хотел бы улучшить функцию.Я знаю, что это немного грязно.Мне было интересно, есть ли лучшие способы решения этой проблемы.Я думаю, что массив не нужен, но я не знаю, как еще это сделать.После того, как массив заполнен всеми меньшими строками, я просто выводю их в текстовый файл.Будем очень благодарны за любые предложения.

Вот функция переноса слов:

void WordWrap(string inputString, string formatedAr[], const int SIZE)
{
    unsigned int index;
    unsigned int word;
    unsigned int max = 65;
    string outWord;
    string outLine;

    outWord = "";
    outLine = "";
    word = 0;

    for(int i = 0; i < SIZE; i++)
    {
        formatedAr[i] = "";
    }

    for(index = 0; index <= inputString.length(); index++)
    {
        if(inputString[index] != ' ')
        {
            outWord += inputString[index];
        }
        else
        {
            if(outLine.length() + outWord.length() > max)
            {
                formatedAr[word] = outLine;
                word++;
                outLine.clear();
            }
            outLine += outWord + " ";
            outWord.clear();
        }
    }
    formatedAr[word] = outLine;
}

И вот где я вызываю функцию и выводю массив:

WordWrap(dvdPtr -> synopsis, formatedAr, SIZE);

index = 0;

while(index < SIZE && formatedAr[index] != "")
{
    outFile << formatedAr[index] << endl;
    index++;
}

1 Ответ

1 голос
/ 28 апреля 2011

Вот пример кода.

#include <iostream>
#include <sstream>
#include <string>
#include <vector>

using namespace std;

void WordWrap(const string& inputString, vector<string>& outputString, unsigned int lineLength)
{
   istringstream iss(inputString);

   string line;

   do
   {
      string word;
      iss >> word;

      if (line.length() + word.length() > lineLength)
      {
         outputString.push_back(line);
         line.clear();
      }
      line += word + " ";

   }while (iss);

   if (!line.empty())
   {
      outputString.push_back(line);
   }
}

/*
A simple test:

Input string: "aaa bbb ccccccc dddd d111111111111111 33333 4444444444 222222222  ajdkjklad 341343"

Length per line: 20

Output lines of strings:

Line 1: aaa bbb ccccccc dddd
Line 2: d111111111111111
Line 3: 33333 4444444444
Line 4: 222222222  ajdkjklad
*/
...