本文参考《C++ Primer 》第五版 15页。
#include <iostream>
using namespace std;
int main()
{
int val = 0, currVal = 0;
if (cin >> currVal) {//先读取了第一个值,
int cnt = 1;//默认当前第一个值的个数为1
while (cin >> val) {//然后拿后面的值来和前面的值作比较
if (val == currVal) {//如果相等,则计数器加一
cnt++;
}
else//如果不相等
{
cout << currVal << ":" << cnt << endl;//说明currVal已经不连续了,则直接打印输出。注意这里是打印连续出现的个数,不是统计所有出现的个数
currVal = val;//从新的值开始计数
cnt = 1;//默认个数为1
}
}
cout << currVal << ":" << cnt << endl;//打印最后一个值出现的个数
//这里我理解一下.分两种情况.1)假如最后输入的值和前面的值相等,也就是执行了上面的if结构.那么它没有输出currVal.这里要补上
//2)假如最后输入的值和前面的值不相等,那么最后这个值没有输出.所以补上
}
return 0;
}
这个算法只能统计出值排列有序的情况,比如1 1 1 2 2 2 3 3 3这种. 如果顺序混乱,比如1 2 1 3 2 1 3 这种则无法统计出来,这时需要参考 https://blog.csdn.net/qq_42110350/article/details/111937734 我的这个文章.