Time Limit: 1 second
Memory Limit: 2 MB
问题描述 求2^n的精确值。n由用户输入,0<=n<=3232。
Input
输入只有一行,一个正整数n。
Output
输出为计算的结果, 最后用回车结束。
Sample Input
8
Sample Output
256(换行) 【题解】
这是个单精度乘高精度的问题,每次在做乘方的时候,把当前算出的结果的每一位都乘上2就可以了,注意要倒序来做。然后用一个变量x来处理进位的问题。最后逆序输出就可以了。
【代码】
#include <cstdio> int n,a[1000],l = 1; void input_data() { scanf("%d",&n); for (int i = 1;i <= 999;i++) //一开始每个位置上的数都置0 a[i] = 0; } void get_ans() { a[1] = 1; for (int i = 1;i <= n;i++) //要乘n次 { int x= 0; for (int j = 1;j <= l;j++) //每一位的数都要乘上2 然后处理进位的问题 用一个x就能搞定 { a[j] = (a[j]*2) + x; x = a[j] / 10; a[j] = a[j] % 10; } while ( x > 0) //如果x 还大于0 就说明2^n的结果的长度还能更长。 { a[++l] += x; x = a[l] / 10; a[l] = a[l] % 10; } } } void output_ans() { for (int i = l;i >= 1;i--) printf("%d",a[i]); } int main() { input_data(); get_ans(); output_ans(); return 0; }