C++:团体程序设计天梯赛(到底有多二)

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

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

输出格式:
在一行中输出N犯二的程度,保留小数点后两位。
编程:
#include< iostream>
#include< string>
using namespace std;
int main()
{
char n[51];
cin >> n;
int len, count = 0;
double s = 1.0;
len = strlen(n);
for (int i = 0; i < len; i++)
{
if (n[i] == ‘2’)
{
count++;
}
}
if (n[0] == ‘-’)
{
s *= 1.5;
len = len - 1;
if (n[len+1] % 2 == 0)
{
s *= 2.0;
}
}
else
{
if (n[len] % 2 == 0)
{
s *= 2.0;
}
}
s = s * count / len;
s = s * 100000;//五位数
int k = (int)s;
int ge, shi, bai, qian, wan;
ge = k % 10;
shi = k / 10 % 10;
bai = k / 100 % 10;
qian = k / 1000 % 10;
wan = k / 10000;
if (ge > 4)
{
shi++;
}
if (wan != 0)
{
cout << wan << qian << “.” << bai << shi << “%” << endl;
}
else
cout << qian << “.” << bai << shi << “%” << endl;
}
上机实践:
在这里插入图片描述

Guess you like

Origin blog.csdn.net/qq_50426849/article/details/121031219