一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
#include<stdio.h>
int main()
{
char m[1000];
int i,n,q=1;
float out,p=1.0,count;
scanf("%s",m);
for(i=0;m[i]!='\0';i++)
{
if(m[i]=='2') count++;//统计字符‘2’的个数,注意是字符。
}
n=i;
if(m[0]=='-'){
p=1.5; //判断第一个字符数是否是符号,因为负号占了一位,所以数字位数-1.
n--;
}
if ((m[i -1] - 48) % 2 ==0)q=2; //判断偶数,这里输入的是ASCLL,要进行转换,不能单一的判断最后一个数字是否是偶数。
out=(float)count/(float)n*p*q*100;
printf("%.2f%%",out); //输出百分号的方法,注意掌握。
return 0;
}
//不建议使用strlen()来算长度,