题干如下:
给出一个由 O 和 X 组成的串(长度为 1~80),统计得分。每个 O 的得分为目前连续出现的 O 的个数,X 的得分为 0 。例如, OOXXOXXOOO 的得分为 1+2+0+0+1+0+0+1+2+3。
题解
解法:遍历输入的字符串,当字符为 “O” 时分数增加,因为 “X” 代表0分,因此不统计
#include <iostream>
#include <cstring>
using namespace std;
char a[85]; //设置字符数组 a
int main(){
int b = 1, score = 0; //b 为统计 “O” 个数时所加的分数
cin >> a;
for(int i = 0; i < strlen(a); i++){ //遍历整个字符串
if(a[i] == 'O') score += b++; //如果 有一个字符是 “O” ,那么得分就增加 b ,同时 b+1
else b = 1; //如果不是 “O” ,b 就重置为 1
}
cout << score;
return 0;
}