到底有多二 PTA

题目:

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

输入格式:

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

输出格式:

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

输入样例:

-13142223336

输出样例:

81.82%

代码实现 :

#include
#include
int main()
{
    char x[51];
    scanf("%s",x);
    int longs=strlen(x);
    float a=1.0;
    int b=1;
    int member=0;
    int m=0;
    for(int i=0;i<(longs);i++)
    {
        if(x[i]=='-')
        {
            a=1.5;
            m++;
        }
        else
        {
            if(x[i]=='2')
                member+=1;
        }
    }
    if((x[longs-1]-'0')%2==0)
        b=2;
    float end=(member*1.0)/(longs-m)*a*b;
    printf("%.2f%%",end*100);
}

注释:

#include
#include
int main()
{
    char x[51];
    scanf("%s",x);
    int longs=strlen(x);//长度
    float a=1.0;//负数倍率
    int b=1;//偶数倍率
    int member=0;//2的数量
    int m=0;//处理负数的情况,用来减小长度
    for(int i=0;i<(longs);i++)
    {
        if(x[i]=='-')//判断负数
        {
            a=1.5;
            m++;
        }
        else
        {
            if(x[i]=='2')
                member+=1;
        }
    }
    if((x[longs-1]-'0')%2==0)//判断偶数
        b=2;
    float end=(member*1.0)/(longs-m)*a*b;//计算概率
    printf("%.2f%%",end*100);//输出
}

注意:

一定要注意负数情况时要将长度减一!!!

你可能感兴趣的:(算法,数据结构,c#,c语言)