unit13高精度課件運算_第1頁
unit13高精度課件運算_第2頁
unit13高精度課件運算_第3頁
unit13高精度課件運算_第4頁
unit13高精度課件運算_第5頁
免費預覽已結束,剩余11頁可下載查看

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、CS101第十三講高精度類型類型范圍范圍占用內存空間占用內存空間char-1281271short-32768327672int-2147483648 7 4long long - 8 + 7 8unsigned short0 655362unsigned int0 4unsigned long long0 158高精度表示int aSIZE; /0SIZE-1,依次從低位到高位儲存數字 /整數轉高精度數 void converti(int *a, int x) int i;for (i=0; x; i+) /當x0時,取每一位數字 ai = x % 10; x /= 10;for (; iS

2、IZE; ai+=0); /字符串轉高精度數void converts(int *a, string s) int i, l;for (l=s.size(), i=0; il; ai=sl-1-i-0, i+);for (; i0 & !ai; i-); for (; i=0; cout char(ai-+0); /高精度數復制,a = bvoid copy(int *a, int *b) int i;for (i=0; i=10; n/=10, i+) if (ai += n%10) = 10) /進位 ai+1+; ai-=10; 高精度-int/高精度-int,相當于a-=n,要

3、求a=n void sub(int *a, int n) int i;for (i=0; n | ai0; n/=10, i+) if (ai -= n%10) =0 void mul(int *a, int n) int i, c=0;for (i=0; i0 void div(int *a, int n) int i, c=0;for (i=SIZE-1; i=0; i-) /模擬豎式除法 c = c%n*10 + ai; /取余數向右計算一位 ai = c/n; /商 高精度%int/高精度%int, 相當于a%=n,要求n0 int mod(int *a, int n) int i,

4、r=0;for (i=SIZE-1; i=0; r=(r*10+ai-)%n);return r; 高精度比較/高精度=高精度bool eq(int *a, int *b) int i;for (i=0; iSIZE & ai=bi; i+);return i=SIZE; /高精度=0 & ai=bi; i-);return i0 | aibi;高精度+高精度/高精度+高精度, 相當于a+=b void add(int *a, int *b, int len=SIZE) int i;for (i=0; i=10) ai+1+;ai-=10;高精度-高精度/高精度-高精度,相當于

5、a-=b, 要求a=b void sub(int *a, int *b, int len=SIZE) int i;for (i=0; ilen; i+) if (ai-=bi)0) ai+1-;ai+=10; 高精度*高精度/高精度*高精度, 相當于c=a*bvoid mul(int *c, int *a, int *b) int i, j;converti(c, 0);for(i=0; iSIZE; i+) for (j=0; j0 void division(int *q, int *r, int *a, int *b) int i;converti(q, 0);copy(r, a);for (i=SIZE-1; !bi; i-);for (i=SIZE-1-i; i=0; i-) for (; lte(b, r+i, SIZE-i); sub(

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論