题目描述
Sabit 爵士是一名高贵的贵族,看遍了人世繁华,他变得热爱异世界文化。

他喜欢在 QQ 群里和他的小伙伴们聊点二次元文化。可经常他们的话有些偏离二次元,这让 Sabit 很苦恼。

我们认为,假如一句话里含有 2 ,那么这句话很二次元。

同时,群里的二次元浓度由二次元话的数量的占比决定。

现在爵士 Sabit 给你看了一眼群里的聊天记录,希望可以知道群里的二次元浓度是多少。
输入描述:
第一行输入一个整数 T (1\leq T\leq 1001≤T≤100),表示数据的组数。对于每组数据:

第一行输入一个整数 n (1\leq n\leq 2001≤n≤200),表示聊天记录的条数。

接下来 n 行每一行输入一个长度不超过 100 的字符串。保证不包含大写字母、小写字母、数字和空格以外的字符,并且没有连续的空格,行末不含空格。
输出描述:
对于每组数据,在一行中输出一个数字表示群里的二次元浓度。

如果你的答案的相对或绝对误差小于 10^{-4}10
−4
,那么它会被认为是正确的。即如果你的答案是 a 而标准答案为 b,那么你的答案将被认为是正确的当且仅当 \frac{|a-b|}{max(1,|b|)}\leq 10^{-4}
max(1,∣b∣)
∣a−b∣

≤10
−4

示例1
输入
复制
2
2
114 514
1919810
3
kokoro ga pyonpyon suru n jaa
2434
without 2
输出

0.0000000000
0.6666666667

简单签到题就是要注意一下,要用getchar去获取回车

#include <bits/stdc++.h>
using namespace std;
char c[1000];
int main()
{
    int t, n, flag;
    double ans;
    scanf("%d", &t);
    while (t--)
    {
        ans = 0, flag = 0;
        scanf("%d", &n);
        getchar();
        for (int i = 1; i <= n; ++i)
        {
            flag = 0;
            gets(c);
            int lc = strlen(c);
            for (int j = 0; j < lc; ++j)
            {
                if (c[j] == '2')
                {
                    flag = 1;
                    break;
                }
            }
            if (flag)
                ++ans;
        }
        printf("%lf\n", double(ans / n * 1.0));
    }
}