麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

關于C語言實現高精度乘法運算

2019-11-14 12:53:33
字體:
來源:轉載
供稿:網友

博主今年剛大一,對C語言并沒有掌握得很好,趁寒假惡補一下,剛好遇見這題,這代碼沒有大神的那么精練。如有錯可以指出。- -。 首先,我們知道,c語言所能表示的數字不是無限大的,32位操作系統中 int 類型最大能到2^32-1(負數比正數多1)。 顯然當要表達的數大于它就無法表示。這時也就有了高精度運算。 其實高精度乘法運算就是用計算機來模擬我們小學學的乘法的運算法則。不啰嗦,先上代碼

#include <stdio.h>#include <string.h>int main(){ char a[1000],b[1000]; //a、b 表示兩個乘數 int c[1000]; //用來存儲算出來的數 int i,j; scanf("%s%s",a,b); //輸入 注意要用char類型 int lentha=strlen(a),lenthb=strlen(b); //計算兩個數的位數 int na[lentha],nb[lenthb]; //注意這種寫法(中括號里是變量)是C99、C11(忘了是哪個- -)的寫法,有些編譯器或oj(像poj - -)會報錯。//把char類型轉換為int類型的,注意要減'0',為什么自己想。。。 for (i=0,j=lentha-1;i<lentha;i++,j--) { na[i]=a[j]-'0'; } for (i=0,j=lenthb-1;i<lenthb;i++,j--) { nb[i]=b[j]-'0'; } for (i=0;i<1000;i++)//初始化 c[i]=0; for (i=0;i<lentha;i++)//核心代碼,5行- -。注意這里沒有進位 for (j=0;j<lenthb;j++) { c[i+j]+=na[i]*nb[j]; } for (i=0;i<lentha+lenthb;i++) //這里進行進位處理,想想為什么lentha+lenthb就夠了,(我也不會證明...) { if (c[i]>=10) { c[i+1]+=c[i]/10; c[i]=c[i]%10; } } for (i=999;i>=0;i--)//這里低位在0這邊,從高位輸出,999其實可以優化但**本人很懶..** if (c[i]!=0||i==0) break; for (;i>=0;i--) 該解釋的解釋完了。 總結一下,其實高精度乘法運算不難。其中這里邊有借鑒其他博主的一些思想在這(最后輸出的那地方)。望多多包涵。這也是本人第一篇博客,水平有限 有錯歡迎指出。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美91看片特黄aaaa | 色交视频 | 美女视频黄视大全视频免费网址 | 久久久青青草 | 日韩av有码在线 | 亚洲午夜天堂吃瓜在线 | 日韩毛片毛片久久精品 | 男女羞羞视频在线观看免费 | 性欧美日本 | 精品国产一区二区三区四 | 中国免费一级毛片 | 国产成人精品区 | 久久久久久久久久久久免费 | 爽爽淫人综合网网站 | 久久亚洲成人 | 一本色道久久99精品综合蜜臀 | 欧美18videos性处按摩 | 视频在线中文字幕 | 粉嫩粉嫩一区二区三区在线播放 | 欧美一级高清片在线 | 手机av在线电影 | 国产在线观看91精品 | 深夜小视频在线观看 | 日韩电影av在线 | 国产精品视频在线观看免费 | 国产一区精品在线观看 | 日本aaa一级片| 精品亚洲视频在线 | 久久久久久久亚洲精品 | 成人在线视频播放 | 久久av免费观看 | 精品在线视频观看 | 国产在线精品一区二区三区不卡 | 国产一区在线视频观看 | 国产精品伊人久久 | 91丝袜| www.成人在线 | 国产精品视频yy9299一区 | 精品一区二区三区中文字幕 | 欧美日本免费一区二区三区 | 久久久久av69精品 |