作者: falcon 發表日期: 2006-05-31 18:46
復制鏈接
先說一下思路哦:
1)先從鍵盤屏幕接收兩個大數,按字符串存放到字符數組中。
2)
初始化進位為0
然后從兩個字符數組中分別取出最后一個字符(數字)開始來求和
一直求和到字符串長度較小的最小下標處停止
結果保存較大數字所存放的字符數組中
(說明:
如果結果大于106,那么結果減去58存入,并記錄進位為1
否則,結果減去48存入,并記錄進位為0
)
3)如果兩個數字的位數不相同,那么需要求出最后一位可能的進位
比如5+96=101
4)進位為1,那么和之前需要輸出一個1
5)輸出兩個大數的和
下面是具體代碼
Code:
[Ctrl+A Select All]
補充:在ubuntu下用gcc編譯通過
部分演示結果
falcon@falcon:~/program/c/code/mylove$ gcc -o add_LN add_LN.c
falcon@falcon:~/program/c/code/mylove$ ./add_LN
Please input two Large Number less than 10000 bit
5
6
兩數之和為:
11
falcon@falcon:~/program/c/code/mylove$ ./add_LN
Please input two Large Number less than 10000 bit
877848515165484151
996527784841515184
兩數之和為:
1874376300006999335
falcon@falcon:~/program/c/code/mylove$ ./add_LN
Please input two Large Number less than 10000 bit
8995951
784784987951252178485215254798749874984185416845865215187484520512
兩數之和為:
784784987951252178485215254798749874984185416845865215187493516463
falcon@falcon:~/program/c/code/mylove$ ./add_LN
Please input two Large Number less than 10000 bit
5
96
兩數之和為:
101
guest 發表于 2007-11-20 23:38
#2
你的C語言代碼有點小錯誤!就是在那段:
if(equal==0)
{
Temp=LN[flag1][LN_Len[flag1]+i]+jw;
if(Temp>=58)
{
jw=1;
LN[flag1][LN_Len[flag1]+i]=Temp-10;
}
else
{
jw=0;
LN[flag1][LN_Len[flag1]+i]=Temp;
}
}
缺少了對一直有進位即JW=1時候的累加!應該加上個while循環:
if(equal==0)
{
while(j>0 && jw==1)
{
Temp=LN[flag1][j+i]+jw;
if(Temp>=58)
{
jw=1;
LN[flag1][j+i]=Temp-10;
}
else
{
jw=0;
LN[flag1][j+i]=Temp;
}
j--;
}
并且初始j=LN_Len[flag1]
歡迎訪問blog.sina.com.cn/Fanmcgrady與我交流!呵呵~~謝謝你的幫助!