请问C语言怎样输出2的64次方,谢谢 #@%~#%#&'_-;/
3条回答 默认 最新
- 「已注销」 2022-10-12 20:59关注
这道题既然前面几位答主的方法不行,可以试试高精度乘法+循环。
先循环64次,中间sum=Mult(sum,2),最后输出。
我测试结果最后一位是6,应该没有问题。
代码:#include<bits/stdc++.h> using namespace std; int a[60],b[60],c[110]; string Mult(string as,int b){ memset(a,0,sizeof(a)); memset(c,0,sizeof(c)); string cs=""; int al=as.size(); int cl=al; for(int i=1;i<=al;i++)a[i]=as[al-i]-'0'; for(int i=1;i<=cl;i++){ c[i]+=a[i]*b; c[i+1]+=c[i]/10; c[i]%=10; } int n=c[cl+1]; while(n){ c[++cl]=n%10; n/=10; } while(c[cl]==0&&cl>1)cl--; for(int i=cl;i>=1;i--)cs+=c[i]+'0'; return cs; } int main() { string sum="1"; for(int i=1;i<=64;i++){ sum=Mult(sum,2); } cout<<sum; return 0; }希望能采纳!谢谢!
本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报解决 1无用 1