高精度计算篇2
本來今天是寫了乘法的,可是突然發現昨天的代碼有問題,根本就是錯誤的,在于計算的方向性,這里模擬真實的算術計算,接收數據應該反過來,如12345,接收過來加入正常接收低位是1,可是實際中應該是高位,不然如果有進位就沒辦法處理了,所以我們要將數據逆向接收!修改后的代碼可以正常運行,看上去也還是很沒水平,不過加油,不要緊,慢慢來!
?
//工程——高精度算術計算by iwaich——2009/10/12
#include <iostream>
#include <string>
using namespace std;
#define MAX 1000
int main()
{
??? int num1[MAX]={0};
??? int num2[MAX]={0};
??? int num3[MAX]={0};
??? memset(num1,0,sizeof(num1));
??? memset(num2,0,sizeof(num2));
??? memset(num3,0,sizeof(num3));
??? int strenth1;
??? int strenth2;
??? string fn;
??? string sn;
??? cout<<"Please input two number for Adding !"<<endl;
??? cin>>fn>>sn;
??? strenth1=fn.length();
??? strenth2=sn.length();
??? for(int i=0, j=strenth1;i<strenth1;i++,j--)
??? {
??? ??? num1[i]=fn[j-1]-'0';
??? }
??? for(int i=0, j=strenth2;i<strenth2;i++,j--)? //不能定義像這樣int i=0,int j=strenth2;
??? {
??? ??? num2[i]=sn[j-1]-'0';
??? }
??? cout<<num1<<endl<<num2<<endl;??? //想這樣輸出數組是不行的,只用char型用數組名輸出,int型由于int占4個字節所以,這樣 只會輸出地址!
??? getchar();
??? int add_length=(strenth1>strenth2?strenth1:strenth2);
??? int i;
??? for(i=0;i<add_length;i++)
??? {
??? ??? num3[i]=num3[i]+num2[i]+num1[i];
??? ??? num3[i+1]=num3[i]/10;
??? ??? num3[i]=num3[i]%10;
??? }
??? if(num3[i]==1)
??? {
??? ??? i=i+1;
??? }
??? int j;
??? for(j=i-1;j>=0;j--)
??? {
??? ??? cout<<num3[j];
??? }
??? cout<<endl;
}
?
關于數組輸出的問題,csdn網友幫助我講解了,我也明白了,引用網友原話是這樣的:
系統給char重載了,只有char具有這樣的功能,所以只有輸出char型數組的時候可以直接輸出數組名,其他情況像int型數組就不行,輸出數組名顯示是數組的首地址!這點要注意啦!
總結
- 上一篇: 软考-信息安全工程师(汇总1000题)
- 下一篇: java实现读取文件返回字节数组