首页 > 代码库 > L1-017. 到底有多二
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%
1 #include<stdio.h> 2 int main() 3 { 4 char a[52],fushu,oushu; 5 double weishu; 6 int i,j,k,len; 7 scanf("%s",a); 8 weishu=0;len=0;fushu=0,oushu=0; 9 for(i=0;a[i]!=‘\0‘;i++) 10 { 11 if(a[i]==‘-‘){ 12 fushu=1; 13 } 14 if(a[i]==‘2‘){ 15 weishu++; 16 } 17 len++; 18 } 19 if((a[len-1]-48)%2==0){ 20 oushu=1; 21 } 22 23 if(oushu && fushu){ 24 printf("%0.2lf%%",weishu/(len-1)*1.5*2*100); 25 } 26 if(fushu && (oushu==0)){ 27 printf("%0.2lf%%",weishu/(len-1)*1.5*100); 28 } 29 if(fushu==0 && oushu){ 30 printf("%0.2lf%%",weishu/(len)*2*100); 31 } 32 if(fushu==0 && oushu==0){ 33 printf("%0.2lf%%",weishu/(len)*100); 34 } 35 36 37 return 0; 38 }
L1-017. 到底有多二
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。