团体程序设计天梯赛-练习集 L1-017 到底有多二

时间:2022-07-24
本文章向大家介绍团体程序设计天梯赛-练习集 L1-017 到底有多二,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

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<stdio.h>
#include<string.h>
int main()
{
    char str[60];
    gets(str);
    int i=0;
    while(str[i++]!='')  //统计字符串的位数
    {

    }
    int len=i-1;
   // printf("len==%dn",len);
    int temp=0;
    for(i=0;i<len;i++)
    {
        if(str[i]=='2') temp++;   //统计字符串中“2”的个数
    }
    double t1=1.0,t2=1.0;
    if((str[len-1]-'0')%2==0)
    {
        t2+=1.0;    //判断是偶数,倍数增加1倍,(1+1*1);
    }
    if(str[0]=='-')
    {
      t1+=0.5;     //判断是负数,倍数增加0.5倍,(1+1*0.5);
      len-=1;
    }
    printf("%.2lf%%n",temp/(double)len*t1*t2*100);
    return 0;
}