L1-017. 到底有多二
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越
一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字“-13142223336”是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11*1.5*2*100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
输入格式:
输入第一行给出一个不超过50位的整数N。
输出格式:
在一行中输出N犯二的程度,保留小数点后两位。
输入样例:-13142223336输出样例:
81.82% 这道题的主要是处理数据的能力 比如偶数的求法,普通的算法就是直接对2取余,但是当数很大的时候,我们就应该取最后那位数判断就行,同理,判断一个数正负就可以直接取第一位就可以了。 以下贴上代码 import java.util.Scanner; public class L1_017 { public static void main(String[] args) { // TODO Auto-generated method stub Scanner in = new Scanner(System.in); while(in.hasNext()){ double count = 0; double m; String s = in.next(); char[] c = s.toCharArray(); for(int i = 0;i<c.length;i++){ if(c[i]=='2'){ count++; } } int ll= (int)c[c.length-1]-48; if(c[0]=='-'){ if(ll%2==0) m = (count/(double)(c.length-1))*1.5*2*100; else m = (count/(double)(c.length-1))*1.5*100; } else{ if(ll%2==0) m = (count/(double)(c.length))*2*100; else m = (count/(double)(c.length))*100; } System.out.printf("%.2f",m); System.out.print("%"); } } } 如有问题可与本人探讨 qq:1500916937