《C++ Primer》第5章 5.4节习题答案

《C++ Primer》第5章 语句

5.4节 迭代语句

练习5.14:编写一段程序,从标准输入中读取若干string对象并查找连续重复出现的单词。所谓连续重复出现的意思是:一个单词后面紧跟着这个单词本身。要求记录连续重复出现的最大次数以及对应的单词。如果这样的单词存在,输出重复出现的最大次数;如果不存在,输出一条信息说明任何单词都没有连续出现过。例如,如果输入是
how now now now brown cow cow
那么输出应该表明单词now连续出现了3次。
【出题思路】
使用while循环遍历用户输入的每一个字符串,根据当前字符串与上一个字符串是否相等决定如何更新各个变量的状态。如果相等,判断当前字符串连续出现的次数是否已经超过了系统记录的值,如果超过则及时更新。
【解答】满足题意的程序如下所示:

#include <iostream>
#include <string>

using namespace std;

int main()
{
    //定义3个字符变量,分别表示:
    //当前操作的字符串,前一个字符串,当前出现次数最多的字符串
    string currString, preString = "", maxString;
    //定义2个整型变量,分别表示:
    //当前连续出现的字tgwfkkh数量\当前出现次数最多的字符串数量
    int currCnt = 1, maxCnt = 0;
    while(cin >> currString)   //检查每个字符串
    {
        //如果当前字符串与前一个字符串一致,更新状态
        if(currString == preString)
        {
            ++currCnt;
            if(currCnt > maxCnt)
            {
                maxCnt = currCnt;
                maxString = currString;
            }
        }
        else  //如果要当前字符串与前一个字符串不一致,重置currCnt
        {
            currCnt = 1;
        }
        //更新preString以便于下一次循环使用
        preString = currString;
    }
    if(maxCnt > 1)
        cout << "出现最多的字符串是:" << maxString << ",次数是:" << maxCnt << endl;
    else
        cout << "每个字符串都只出现了一次" << endl;
    
    return 0;
}

运行结果:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值