【PTA】​到底有多二​ (C++)

简介: 【PTA】​到底有多二​ (C++)

题目链接: 到底有多二

题目要求:

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

输入格式:

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

输出格式:

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

输入样例:

-13142223336

输出样例:

81.82%

思路:

1.先按字符串将其输入

2.判断是否为负数或者是否为偶数,分别对应的倍数求出来

3.遍历字符串判断2的个数

4.进行运算先要判断这个字符串里面有没有负号,有负号分母就是总长度减1,如果没有则字符串长度就是数字的总个数。

5.用printf进行输出

代码:

#include <bits/stdc++.h>
 
using namespace std;
 
int main()
{
    string s;
    cin >> s;
    double x1 = 1.0 , x2 = 1.0;
    double x;     //最终结果
    double k = 0;    //记录2的个数
    if(s[0] == '-')    //判断是否为-
        x1 = 1.5;
    if((s[s.size()- 1] - '0') % 2 == 0)//判断是否为偶
        x2 = 2.0;
    
    for(int i = 0; i < s.size(); i ++)
    {
        if(s[i] == '2') 
            k ++;
    }
    if(x1 == 1.5)
    {
        x = (k / (s.size() - 1) * x1 * x2) * 100;
    }
    else
    {
        x = (k / s.size() * x1 * x2) * 100;
    }
 
    printf("%.2lf%%\n",x);
    return 0;
}

测试结果:


目录
打赏
0
0
0
0
28
分享
相关文章
|
8月前
|
C++
【PTA】L1-016 验证身份(C++)
【PTA】L1-016 验证身份(C++)
101 0
【PTA】L1-016 验证身份(C++)
|
7月前
|
【PTA】L1-039 古风排版(C++)
【PTA】L1-039 古风排版(C++)
61 1
|
8月前
|
部落(pta)(并查集) Java以及C++
部落(pta)(并查集) Java以及C++
67 2
【PTA】L1-064 估值一亿的AI核心代码(详C++)
【PTA】L1-064 估值一亿的AI核心代码(详C++)
64 1
|
7月前
|
【PTA】L1-059 敲笨钟(C++)
【PTA】L1-059 敲笨钟(C++)
56 1
【PTA】L1-093 猜帽子游戏(C++)
【PTA】L1-093 猜帽子游戏(C++)
141 1
|
7月前
|
C++
【PTA】L1-046 整除光棍(C++)
【PTA】L1-046 整除光棍(C++)
77 1
|
7月前
|
【PTA】L1-043 阅览室(C++)
【PTA】L1-043 阅览室(C++)
38 1
|
7月前
|
【PTA】​L1-034 点赞(C++)
【PTA】​L1-034 点赞(C++)
38 0