这个程序的目标应该是生成一个输出字符串,使得:
- 输出字符串 + 介于 == 之间的空格 == 宽度。
- 字符串不会被切断。因此,它每行给出完整的单词。
这是我到目前为止所拥有的:
int main()
{
int width= 15;
vector<string> line;
line.push_back("Hello");
line.push_back("My");
line.push_back("Name");
line.push_back("Is");
line.push_back("John");
auto s = line.front();
for (auto i = std::size_t {1}; i < line.size(); ++i) s += ' ' + line[i];
for (size_t i = 0; i < s.length(); i+=width+1)
{
s.insert(i,"n");
}
cout<<s;
}
我不想在单词之间均匀地添加空格,这样最后一个字符串就不会被截断并移动到下一行。
这类似于C++案文充分理由的问题。但我想纠正我自己的实现以解决此问题.
您正在做的是在字符串已经形成后将新行插入字符串,从而可能将单词剪切到新行。
如果在添加另一个单词之前插入一个新单词,最好检查字符串的长度是否会大于行的所需宽度。
这就是我能想到的
int main()
{
int width= 15;
vector<string> line;
line.push_back("Hello");
line.push_back("My");
line.push_back("Name");
line.push_back("Is");
line.push_back("John");
std::string s {};
for (int i {0}; i < line.size(); ++i)
{
if( (s + line[i] + " ").size() <= width)
{
s += line[i] + " ";
}
else
{
s += "n" + line[i] + " ";
width += width;
}
}
cout<<s;
}