【基础算法】牛牛掷硬币【基础】

传送门

牛牛掷硬币

AC代码

第一种写法:找规律

class Solution {
     
public:
    /**
     * 返回一个严格四舍五入保留两位小数的字符串
     * @param n int整型 n
     * @return string字符串
     */
    string Probability(int n) {
     
        // write code here
        double ans = 1;
        if (n == 1) return "1.00";
        if (n == 2) return "0.50";
        if (n == 3) return "0.25";
        if (n == 4) return "0.13";
        if (n == 5) return "0.06";
        if (n == 6) return "0.03";
        if (n == 7) return "0.02";
        if (n == 8) return "0.01";
        return "0.00";
    }
};

第二种写法:round函数

class Solution {
     
public:
    /**
     * 返回一个严格四舍五入保留两位小数的字符串
     * @param n int整型 n
     * @return string字符串
     */
    string Probability(int n) {
     
        if(n==1) return "1.00";
        n -= 1;
        double sum = 1.0;
        for(int i = 1; i <= min(n,10); i++){
     
            sum = sum / 2.0;
        }
        int tmp = round(sum*100);
        string str = "0.";
        str.push_back((tmp/10)+'0');
        str.push_back((tmp%10)+'0');
        return str;
    }
};

第三种写法:sprintf
注意:没有ans += 1e-7会通过90%。

class Solution {
     
public:
    /**
     * 返回一个严格四舍五入保留两位小数的字符串
     * @param n int整型 n
     * @return string字符串
     */
    string Probability(int n) {
     
        char str[233];
        double ans = 1.0;
        for(int i = 1; i <= min(n,100); i++) ans /= 2.0;
        ans *= 2;
        ans += 1e-7;
        sprintf(str,"%.2lf",ans);
        return str;
        // write code here
    }
};

你可能感兴趣的:(ACM,#,基础算法,基础算法)