一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
输入格式:
输入第一行给出一个不超过50位的整数N。
输出格式:
在一行中输出N犯二的程度,保留小数点后两位。
输入样例:
-13142223336
输出样例:
81.82%
题解:
#include<iostream>
#include<string.h>
using namespace std;
int main(){
string n;
// 判断是否有负号 判断是否是偶数
bool isMinus = false, evenNumber = false;
cin >> n;
if (n[0] == '-'){
isMinus = true;
}
if ((n[n.length() - 1] - '0') % 2 == 0){
evenNumber = true;
}
int numberLength = 0;//数字位数
if (isMinus == true){//有负号扣去一位
numberLength = n.length() - 1;
}else{
numberLength = n.length();
}
int two = 0;//数字中出现2的个数
for (int i = 0; i < n.length(); i++){
if (n[i] == '2'){
two++;
}
}
double ans = 0;//最终结果
ans = (double)two / (double)numberLength * 100;
//如果是偶数或是负数,乘上相应的倍数
if (isMinus){
ans *= 1.5;
}
if (evenNumber){
ans *= 2.0;
}
printf("%.2f%%", ans);//注意:百分号打印格式:%%---》转义字符
return 0;
}

被折叠的 条评论
为什么被折叠?



