L1-017 到底有多二

题目描述

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。

输入格式

输入第一行给出一个不超过50位的整数N。

输出格式

在一行中输出N犯二的程度,保留小数点后两位。

输入样例

-13142223336

输出样例

81.82%

题解思路

按字符串处理。

题解代码

#include 
using namespace std;

int main(){
    char s[60];
    scanf("%s", s);
    double cnt = 0;
    double er = 0;
    double key1 = 1, key2 = 1;
    for(int i = 0; s[i] != 0; i++){
        cnt += 1;
        if(s[i] == '-'){
            key1 = 1.5;
            cnt--;
        }
        if(s[i] == '2'){
            er += 1;
        }
        if(s[i + 1] == 0 && s[i] % 2 == 0){
            key2 = 2;
        }
    }
    printf("%.2lf%%", (er / cnt) * key1 * key2 * 100);
    return 0;
}

你可能感兴趣的:(L1-017 到底有多二)