您的位置:首页 > 其它

7-1 到底有多二(15 分)

2018-03-16 20:23 344 查看
题目链接

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。

输入格式:

输入第一行给出一个不超过50位的整数N。

输出格式:

在一行中输出N犯二的程度,保留小数点后两位。

输入样例:

-13142223336

输出样例:

81.82%

#include<algorithm>
#include<iostream>
#include<vector>
using namespace std;
int main(){
vector <int> arr;
string s;
cin>>s;
int i;
s[0] == '-' ? i = 1 : i = 0;
for(;i < s.length();i++)
arr.push_back(s[i]-'0');
int cnt = count(arr.begin(),arr.end(),2);
if(s[0] == '-'){
if(arr[arr.size()-1] % 2 == 0)
printf("%.2lf%%\n",((double)cnt)/arr.size()*1.5*2*100);
else
printf("%.2lf%%\n",((double)cnt)/arr.size()*1.5*100);
}
else{
if(arr[arr.size()-1] % 2 == 0)
printf("%.2lf%%\n",((double)cnt)/arr.size()*2*100);
else
printf("%.2lf%%\n",((double)cnt)/arr.size()*100);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: