青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0
在計算機中,長整型(long int)變量的范圍是 -2147483648 至 2147483647,因此若用長整型變量做乘法運算,乘積最多不能超過 10位數。即便用雙精度型(double)變量,也僅能保證 16 位有效數字的精度。在某些需要更高精度的乘法運算的場合,需要用別的辦法來實現乘法運算。 比較容易想到的是做多位數乘法時列豎式進行計算的方法,只要寫出模擬這一過程的程序,就能實現任意大整數的乘法運算。經過查閱資料,找到一種更易于編程的方法,即“列表法”。 下面先介紹“列表法”: 例如當計算8765 x 234時,把乘數與被乘數照如下列出,見表1: 8 7 6 5 8765 2 16 14 12 10 2 3 24 21 18 15 3 4 32 28 24 20 4 表 1 表 2 把每個空格所在的行列的數字的乘積填入空格中,得表2。把表2中的數按圖示斜線分組(橫縱坐標和相等的數分為一組),把每組數的累加起來所得的和記在表格下方,見表 3: 16 14 12 10 24 21 18 15 32 28 24 20 16 38 65 56 39 20 表 3 最后把表格下方一行數作如下處理,見表4: 從最低位的 20 開始,保留個位數字“0”,把個位以外的數“2”進到前一位;把次低位的 39 加上低位進上來的 2 得 41,保留個位數字“1”,把“4”進到前一位;以此類推,直至最高位的 16,16 加上低位進上來的4得 20,保留“0”,把2進到最高位,得乘積答數 2051010。 16 38 65 56 39 20 2 16+4=20 38+7=45 65+6=71 56+4=60 39+2=41 留0進2 留5進4 留1進7 留0進6 留1進4 留0進2 2 0 5 1 0 1 0 表 4 根據以上思路就可以編寫C 程序了,再經分析可得: 1、一個m 位的整數與一個 n 位的整數相乘,乘積為m+n-1 位或m+n 位。 2、程序中,用三個字符數組分別存儲乘數、被乘數與乘積。由第 1 點分析知,存放乘積的字符數組 的長度應不小于存放乘數與被乘數的兩個數組的長度之和。 3、可以把第二步“計算填表”與第三四步“累加進位”放在一起完成,可以節省存儲表格 2所需的空間。 4、程序關鍵部分是兩層循環,內層循環累計一組數的和,外層循環處理保留的數字與進位。 編寫的程序如下: 程序 1 清單: /* multiply.c */ /* 11/20/2008 */ #define MAXLENGTH 1000 #include #include void compute(char *a, char *b, char *c); void main(void) { char a[MAXLENGTH], b[MAXLENGTH], c[MAXLENGTH * 2]; puts("Input multiplier :"); gets(a); puts("Input multiplicand :"); gets(b); compute(a, b, c); puts("Answer :"); puts(c); getchar(); } void compute(char *a, char *b, char *c) { int i, j, m, n; long sum, carry; m = strlen(a) - 1; n = strlen(b) - 1; for (i = m; i >= 0; i--) a[i] -= '0'; for (i = n; i >= 0; i--) b[i] -= '0'; c[m + n + 2] = '\0'; carry = 0; for (i = m + n; i >= 0; i--) /* i 為坐標和 */ { sum = carry; if ((j = i - m) < 0) j = 0; for ( ; j<=i && j<=n; j++) /* j 為縱坐標 */ sum += a[i-j] * b[j]; /* 累計一組數的和 */ c[i + 1] = sum % 10 + '0'; /* 算出保留的數字 */ carry = sum / 10; /* 算出進位 */ } if ((c[0] = carry+'0') == '0') /* if no carry, */ c[0] = '\040'; /* c[0] equals to space */ } 效率分析:用以上算法計算 m位整數乘以n 位整數,需要先進行 m x n次乘法運算,再進行約 m + n次加法運算和 m + n次取模運算(實為整數除法)。把這個程序稍加修改,讓它自己產生乘數與被乘 數,然后計算隨機的 7200位整數互乘,在Cyrix 6x86 pr166機器的純DOS方式下耗時 7秒(用Borland C 3.1編譯)。 經過改進,此算法效率可以提高約9 倍。 注意到以下事實:8216547 x 96785 將兩數從個位起,每 3位分為節,列出乘法表,將斜線間的 數字相加; 8 216 547 96 785 768 20736 52512 6280 169560 429395 768 27016 222072 429395 將表中最后一行進行如下處理:從個位數開始,每一個方格里只保留三位數字,超出 1000 的部 分進位到前一個方格里; 768 27016 222072 429395 768+27 27016+222 222072+429 =795 =27238 =222501 395 795 238 501 395 所以8216547 x 96785 = 795238501395 也就是說我們在計算生成這個二維表時,不必一位一位地乘,而可以三位三位地乘;在累加時也是滿1000進位。這樣,我們在計算 m位整數乘以 n位整數,只需要進行 m x n / 9次乘法運算,再進行約(m + n) / 3次加法運算和(m + n) /3 次取模運算。總體看來,效率約是前一種算法的 9倍。 有人可能會想:既然能夠三位三位地乘,為什么不4位 4位甚至5位5位地乘呢?那不是可以提高 16 乃至 25 倍效率嗎?聽我解來:本算法在累加表中斜線間的數字時,如果用無符號長整數(范圍 0至~4294967295)作為累加變量,在最不利的情況下(兩個乘數的所有數字均是 9),能夠累加約4294967295/(999*999)=4300 次,也就是能夠準確計算任意兩個均不超過 12900(每次累加的結果"值"三位,故 4300*3=12900)位的整數相乘。如果 4 位 4 位地乘,在最不利的情況下,能夠累加約4294967295/(9999*9999)=43 次,僅能夠確保任意兩個不超過 172 位的整數相乘,沒有什么實用價值,更不要說5位了。 請看改進后的算法的實例程序: 該程序隨機產生兩個72xx位的整數,把乘數與積保存在 result.txt中。 在Borland C++ 3.1 中用 BCC -3 -O2 -G -mh -Z -f287 -pr -T- dashu.cpp 編譯生成的exe文件在Cyrix 6x86 pr166的機器上運行耗時0.82 秒。 程序 2 清單: #include #include #include #include #include #define N 7200 //作 72xx 位的整數乘法 int max(int,int,int); int initarray(int a[]); void write(int a[],int l); FILE *fp; void main() { int a[5000]={0},b[5000]={0},k[10001]={0}; //聲明存放乘數、被乘數與積的數組 clock_t start, end; //聲明用于計時的變量 unsigned long c,d,e; //聲明作累加用的無符號長整數變量 int i,j,la,lb,ma,mi,p,q,t; //聲明其它變量 randomize(); //初始化隨機數 la=initarray(a); //產生被乘數,并返回其長度 lb=initarray(b); //產生乘數,并返回其長度 if(lala)?lb:la; for (q=0;q=0;i--) //累加斜線間的數,i 為橫縱坐標之和 { c=d; //將前一位的進位標志存入累加變量 c ma=max(0,i-la+1,i-lb+1); //求累加的下限 mi=(i>la-1)?(la-1):i; //求累加的上限 for(j=ma;j<=mi;j++) //計算出橫縱坐標之和為 i 的單元內的數,并累加到 C 中 c+=(long)a[j]*b[i-j]; d=c/1000; //求進位標志 if(c>999) c%=1000; //取 c 的末三位 k[i]=c; //保存至表示乘積的數組 k[] } e=k[0]+1000*d; //求出乘積的最高位 end = clock();//停止計時 fp = fopen("result.txt", "w+"); //保存結果到 result.txt printf("\nThe elapsed time was: %3.4f\n", (end - start) / CLK_TCK); //打印消耗的時間 fprintf(fp,"%d",a[0]); //打印被乘數最高位 write(a,la); //打印被乘數其他位 fprintf(fp,"%d",b[0]); //打印乘數最高位 write(b,lb); //打印乘數其他位 fprintf(fp,"%ld",e); //打印乘積最高位 write(k,la+lb-1); //打印乘積其他位 fclose(fp); } max(int a,int b,int c) { int d; d=(a>b)?a:b; return (d>c)?d:c; } int initarray(int a[]) { int q,p,i; q=N+random(100); if(q%3==0) p=q/3; else p=q/3+1; for(i=0;iposted on 2009-12-06 23:26 chatler 閱讀(1147) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm
<2012年4月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产欧美大片| 亚洲日本免费| 亚洲免费黄色| 免费亚洲一区二区| 91久久精品国产91性色| 国产麻豆午夜三级精品| 亚洲图片自拍偷拍| 亚洲小说春色综合另类电影| 91久久午夜| 亚洲一区在线免费观看| 亚洲精品黄色| 亚洲在线国产日韩欧美| 亚洲午夜激情免费视频| 亚洲精品影视在线观看| 亚洲精品在线观看免费| 亚洲激情一区| 在线一区二区视频| 亚洲影院在线观看| 欧美尤物巨大精品爽| 欧美国产三区| 国产精品免费久久久久久| 亚洲欧洲日产国产综合网| 亚洲第一中文字幕| 嫩草国产精品入口| 亚洲激情社区| 亚洲欧洲三级| 亚洲在线第一页| 免费在线观看一区二区| 国产精品久久久久aaaa九色| 亚洲视频免费观看| 久久米奇亚洲| 久久久av毛片精品| 国产精品久久| 亚洲激情网站| 亚洲国产精品va在线看黑人动漫| 久久久www成人免费精品| 国产精品video| 亚洲美女黄网| 欧美成人免费全部| 久久久久久欧美| 亚洲国产精品va在线观看黑人| 亚洲欧美成人网| 亚洲视频综合在线| 欧美体内谢she精2性欧美| 欧美日韩国产天堂| 美女精品在线| 国产精品高潮呻吟久久av无限| 国产欧美韩国高清| 欧美成人一区二区三区片免费| 亚洲永久精品大片| 亚洲图片在线观看| 欧美一区二区三区久久精品| 在线观看成人小视频| 欧美亚洲视频一区二区| 香蕉久久精品日日躁夜夜躁| 国产专区综合网| 欧美日韩亚洲一区| 亚洲精品视频在线播放| 小辣椒精品导航| 国产精品一区一区三区| 亚洲一本视频| 久久先锋资源| 久久综合一区二区三区| 亚洲免费一级电影| 欧美日韩免费看| 久久激情久久| 欧美精品高清视频| 99精品热视频只有精品10| 日韩视频永久免费观看| 99伊人成综合| 美女91精品| 亚洲成人在线| 欧美另类专区| 亚洲一区精品电影| 韩日欧美一区二区三区| 亚欧美中日韩视频| 国产精品一区二区在线观看网站| 亚洲在线观看| 久久尤物视频| 亚洲国产精品一区在线观看不卡| 国产精品一区视频网站| 亚洲欧美日本国产专区一区| 国产精品美女久久久免费| 国产精品欧美日韩一区| 另类春色校园亚洲| 欧美日韩国产成人在线91| 久久久人成影片一区二区三区| 欧美日韩卡一卡二| 欧美专区福利在线| 欧美+日本+国产+在线a∨观看| 日韩视频中午一区| 午夜国产一区| 伊人精品视频| 欧美在线视频免费观看| 韩国成人精品a∨在线观看| 亚洲视频成人| 亚洲久久成人| 久久尤物电影视频在线观看| 亚洲影视在线播放| 亚洲综合视频1区| 激情婷婷欧美| 一区二区国产日产| 国产日本亚洲高清| 欧美xx69| 亚洲欧美在线播放| 夜夜嗨av色一区二区不卡| 亚洲二区在线观看| 一区二区三区欧美激情| 午夜久久美女| 亚洲区国产区| 亚洲国产一区二区视频| 性做久久久久久久免费看| 日韩手机在线导航| 国产在线视频不卡二| 欧美日韩99| 亚洲国产欧美一区| 亚洲激情国产| 欧美亚一区二区| 欧美电影免费观看高清| 欧美一区二区三区另类| 中文网丁香综合网| 亚洲先锋成人| 欧美亚洲视频| 99国产精品久久久久久久| 在线精品视频免费观看| 伊人激情综合| 一区二区三区免费网站| 国产一区清纯| 亚洲欧洲一区| 久久九九免费视频| 亚洲美女中文字幕| 亚洲高清二区| 91久久精品国产91性色| 亚洲高清视频一区二区| 欧美激情第8页| 久久人人97超碰人人澡爱香蕉| 亚洲校园激情| 亚洲激情在线视频| 久久精品在线免费观看| 欧美成人第一页| 亚洲一区二区三区免费在线观看| 一区二区三区日韩欧美| 男同欧美伦乱| 国产午夜精品麻豆| 亚洲视频精选在线| 午夜精品免费视频| 亚洲激情女人| 欧美成人在线免费视频| 国产日本欧美一区二区| 日韩视频在线永久播放| 国产乱码精品| 亚洲图片欧美午夜| 一区二区欧美日韩视频| 久久综合激情| 亚洲精品极品| 午夜精品区一区二区三| 欧美二区在线观看| 美女主播一区| 欧美成ee人免费视频| 欧美v亚洲v综合ⅴ国产v| 国产精品福利在线观看| 一区二区三区鲁丝不卡| 欧美精品在线观看| 亚洲卡通欧美制服中文| 欧美与黑人午夜性猛交久久久| 亚洲视频在线观看免费| 久久精品视频免费| 美女诱惑黄网站一区| 快she精品国产999| 欧美喷水视频| 久久久在线视频| 免费欧美在线视频| 亚洲免费在线看| 欧美色精品天天在线观看视频| 亚洲精选中文字幕| 免费在线观看日韩欧美| 亚洲欧美春色| 国产九九精品| 欧美亚洲三区| 亚洲欧美一级二级三级| 欧美午夜片在线观看| 亚洲黄色视屏| 久久噜噜噜精品国产亚洲综合| 亚洲欧美一区在线| 国产精品色在线| 久久久噜噜噜久久久| 免费高清在线视频一区·| 1024日韩| 欧美电影免费观看高清| 亚洲午夜国产一区99re久久| 亚洲欧美日韩成人| 国产日本欧美在线观看| 久久久99国产精品免费| 久久综合激情| 日韩亚洲欧美一区二区三区| 一区二区三区精品视频| 欧美日韩成人免费| 亚洲欧美中文在线视频| 欧美肥婆bbw| 亚洲国产一区二区a毛片|