[UVA 545] Heads 题解

题意:给出 \(n\) 题目让你求 \(2\)\(-n\) 次方,即 \(2^{-n}\)c++

我不会算负次方。怎么办, Bing一下啊!spa

一个数的负次方等于这个数的多少次方的倒数。code

按照定义,咱们来分别肯定幂的值。ci

首先是幂是负数。it

按照定义,咱们能够推得 \(e=-n\times\log(2)\)class

这样就能够把数据给格式化输出,最后只要计算出 \(10^{-n\times\log(2)-e}\) 而后输出 \(e\) 次方便可。im

Talk is cheap, show me the Code.数据

#include <bits/stdc++.h>
using namespace std;
int main(){
    int T, n;
    cin>>T;
    while(T--) {
        cin>>n;
        int e=floor(-n * log10(2));
        printf("2^-%d = %.3lfE%d\n",n,pow(10,-n*log10(2)-e),e);
    }
}
相关文章
相关标签/搜索