问题描述
- c++primer 5.4.1 练习问题
-
编写一段程序,从标准输入中读取若干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;
解决方案
C++Primer第五版 7.1.2节练习
C++Primer第五版 12.1.2节练习
C++Primer第五版 9.2.7节练习
解决方案二:
内外循环条件,导致iterator 越界。
解决方案三:
像这种问题运行时崩溃的基本都是非法访问内存,或者跟内存有关的问题,好好检查检查,调试调试就可以找出来了...
解决方案四:
while循环内的判断导致越界,i=end()—1的时候,i+1已经越界。
时间: 2024-11-03 18:41:25