L1-017 到底有多二
一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
输入格式:
输入第一行给出一个不超过50位的整数N。
输出格式:
在一行中输出N犯二的程度,保留小数点后两位。
输入样例:
-13142223336
输出样例:
81.82%
C语言参考代码:
#include<stdio.h>
#include<string.h>
int main(){
char s[51];
char n;
scanf("%s",&s);
double x=0,k=0,a=1,b;
for(int i=0;s[i]!='\0';i++){
if(s[i]=='-')a*=1.5;
else k++;
if(s[i]=='2')x++;
n=s[i];
}
int c;
c=n-'0';
if(c%2==0)b=2;
else b=1;
double sum;
sum=x*a*b*100/k;
printf("%.2f%%\n",sum);
return 0;
}
C++参考代码:
#include<iostream>
#include<iomanip>
using namespace std;
int main(){
char s,n;
double x=0,k=0,a=1,b;
while(cin>>s){
if(s=='-')a*=1.5;
else k++;
if(s=='2')x++;
n=s;
}
int c;
c=n-'0';
if(c%2==0)b=2;
else b=1;
double sum;
sum=x*a*b*100/k;
cout<<fixed<<setprecision(2)<<sum<<"%";
return 0;
}
Python参考代码:
N = input()
if N[0] == '-':
k = 0
for i in N:
if i == '2':
k = k + 1
if int(N[-1]) % 2 == 0:
m = k * 1.5 * 2 / (len(N) - 1)
else:
m = k * 1.5 / (len(N) - 1)
else:
k = 0
for i in N:
if i == '2':
k = k + 1
if int(N[-1]) % 2 == 0:
m = k * 2 / (len(N))
else:
m = k / (len(N))
print("%.2f" % (m * 100), end='')
print('%')
Golang参考代码:
package main
import "fmt"
func main() {
var str string
count := 0.0
k := 1.0
d := 1.0
fmt.Scanf("%s",&str)
for _,s:=range str {
if s=='2'{
count++
}
}
end:=int(str[len(str)-1]-'0')
if end%2==0 {
d=2.0
}
l:=len(str)
if string(str[0])=="-"{
k=1.5
l=l-1
}
result := count*k*d*100/float64(l)
fmt.Printf("%.2f%%",result)
}