c语言1 2 3 10000,在网上看到一个求2的10000次方的方法,有个地方看不懂,求大佬...
該樓層疑似違規(guī)已被系統(tǒng)折疊?隱藏此樓查看此樓
#include "stdio.h "
int main(void)
{
static unsigned int temp[1024];/*分段儲(chǔ)存數(shù)據(jù)*/
unsigned int position=1;/*記錄共有幾段*/
int overflow=0; /*記錄在算每一段時(shí)是否溢出*/
long
times=10000,tm_cnt,sgn_cnt;/*默認(rèn)10000次計(jì)算,可以更改,兩個(gè)計(jì)數(shù)器(乘方次數(shù),段的位置)*/
temp[0]=2;/*初始值為2*/
if(times> 13000)
{
printf( "your input is too large ");/*檢查輸入是否越界*/
exit(0);
}
/*開(kāi)始計(jì)算,外層為乘方次數(shù),內(nèi)層為每一位計(jì)算*/
for(tm_cnt=0;tm_cnt
{
for(sgn_cnt=0;sgn_cnt
{
temp[sgn_cnt] < <=1;/*相當(dāng)于乘2*/
if(overflow==1) /*檢查上次是否有溢出*/
{
/*有的話,將溢出加到這一段,同時(shí)置溢出為0*/
++temp[sgn_cnt];
overflow=0;
}
if(temp[sgn_cnt]> 9999)
{
/*檢查本次是否溢出,溢出的話,*/
temp[sgn_cnt]-=10000;
overflow=1;
}
}
if(overflow==1)
{
++position;
++temp[sgn_cnt];???????????????(為什么溢出了,我正在計(jì)算的元素要+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;
}
總結(jié)
以上是生活随笔為你收集整理的c语言1 2 3 10000,在网上看到一个求2的10000次方的方法,有个地方看不懂,求大佬...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: c语言中缺少link文件夹,c – Cm
- 下一篇: android实现录像功能吗,Andro