Silentlove_
Silentlove_
2015-11-20 16:11

c++primer 5.4.1 练习问题

  • c++
  • ios

编写一段程序,从标准输入中读取若干string对象并查找连续重复出现的单词。所谓连续重复出现的意思是:一个单词后面紧跟着这个单词本身。要求记录连续重复出现的最大次数以及对应单词。如果这样的单词存在,输出重复出现的最大次数;如果不存在,输出一条信息说明任何单词都没有连续出现过。例如,如果输入是

how now now now brown cow cow

那么输出应该表明单词now连续出现了3次。
我的代码
#include
#include
#include
using namespace std;
int main()
{
vectortext;
string word;
while (cin >> word)
{
text.push_back(word);
}
int cnt = 1;
int b = 1;
auto c = text.begin();
for (auto i = text.begin(); i !=(text.end()); ++i)
{

    while (i !=(text.end()) && *i == *(i + 1)  )
    { 
        ++cnt;
        ++i;
    }
    if (cnt >= b)
    {
         c = i;
        b = cnt;
    }

     cnt = 1;


}
if (cnt != 1)
        cout << "the word " << *c << " shows " << cnt << " times in a row" << endl;

if (cnt == 1)
        cout << "no one word has lianxu" << endl;
return 0;

}
但是最后图片说明

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

3条回答

为你推荐