数组计算2的10000次方C语言,在网上看到一个求2的10000次方的方法,有个地方看不懂,求大佬...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

#include "stdio.h "

int main(void)

{

static unsigned int temp[1024];/*分段储存数据*/

unsigned int position=1;/*记录共有几段*/

int overflow=0; /*记录在算每一段时是否溢出*/

long

times=10000,tm_cnt,sgn_cnt;/*默认10000次计算,可以更改,两个计数器(乘方次数,段的位置)*/

temp[0]=2;/*初始值为2*/

if(times> 13000)

{

printf( "your input is too large ");/*检查输入是否越界*/

exit(0);

}

/*开始计算,外层为乘方次数,内层为每一位计算*/

for(tm_cnt=0;tm_cnt

{

for(sgn_cnt=0;sgn_cnt

{

temp[sgn_cnt] < <=1;/*相当于乘2*/

if(overflow==1) /*检查上次是否有溢出*/

{

/*有的话,将溢出加到这一段,同时置溢出为0*/

++temp[sgn_cnt];

overflow=0;

}

if(temp[sgn_cnt]> 9999)

{

/*检查本次是否溢出,溢出的话,*/

temp[sgn_cnt]-=10000;

overflow=1;

}

}

if(overflow==1)

{

++position;

++temp[sgn_cnt];???????????????(为什么溢出了,我正在计算的元素要+1)

overflow=0;??????????????????(为什么要把溢出归0,这不是失去意义了吗)

}

if(position> 1023)

{

printf( "times: %d error! ",tm_cnt);

exit(1);

}

}

printf( "%d ",temp[sgn_cnt-1]);

for(sgn_cnt=position-2;sgn_cnt> =0;sgn_cnt--)

{

if(temp[sgn_cnt] <1000)

printf( "0 ");

if(temp[sgn_cnt] <100)

printf( "0 ");

if(temp[sgn_cnt] <10)

printf( "0 ");

printf( "%d ",temp[sgn_cnt]);

if((sgn_cnt+1)%15==0)

printf( "\n ");

}

return 0;

}


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部