编写一段程序,从标准输入中读取若干string对象,并且查找连续的重复出现的单词。所谓连续重复出现的意思是:一个单词都免紧跟着这个单词本身。要求记录连续重复出现的最大次数及对应的单词。
输入结束后,用Ctrl+Z 结束输入,一开始不知道怎么退出输入,很蛋疼。。。
#include"stdafx.h"
#include<iostream>
#include<string>
using namespace std;
int main()
{
//定义三个字符串变量,分别表示当前的,前一个和出现次数最多的
string currString, preString = "", maxString;
//定义两个变量,记录当前字符串出现的次数和目前出现的最大次数
int currCnt = 1, maxCnt=0;
while (cin>>currString)
{
//如果当前字符串与前一个一致,则更新状态
if (currString == preString )
{
++currCnt;
if (currCnt>maxCnt)
{
maxCnt = currCnt;
maxString = currString;
}
}
else
{
currCnt = 1;//不一样的话,就直接置1
}
preString = currString;//将当前字符串送给上一个字符串,为后面比较使用
}
if (maxCnt > 1)
{
cout << "出现最多的字符串是:" << maxString << ",次数是:" << maxCnt << endl;
}
else
cout << "每个字符串都只出现了一次" << endl;
system("pause");
return 0;
}