求编写一个C语言大数乘法的程序,尽量简单一些,要求每一步有详细讲解.
来源:学生作业帮 编辑:搜狗做题网作业帮 分类:综合作业 时间:2024/08/12 07:09:04
求编写一个C语言大数乘法的程序,尽量简单一些,要求每一步有详细讲解.
C语言题目之大数乘法.程序尽量用比较基础的方法.希望每一步都有比较详细通俗的讲解(像老师讲课的话语).这个是用于做一个演讲.悬赏150分,(用C不用C++)
C语言题目之大数乘法.程序尽量用比较基础的方法.希望每一步都有比较详细通俗的讲解(像老师讲课的话语).这个是用于做一个演讲.悬赏150分,(用C不用C++)
![求编写一个C语言大数乘法的程序,尽量简单一些,要求每一步有详细讲解.](/uploads/image/z/2836679-23-9.jpg?t=%E6%B1%82%E7%BC%96%E5%86%99%E4%B8%80%E4%B8%AAC%E8%AF%AD%E8%A8%80%E5%A4%A7%E6%95%B0%E4%B9%98%E6%B3%95%E7%9A%84%E7%A8%8B%E5%BA%8F%2C%E5%B0%BD%E9%87%8F%E7%AE%80%E5%8D%95%E4%B8%80%E4%BA%9B%2C%E8%A6%81%E6%B1%82%E6%AF%8F%E4%B8%80%E6%AD%A5%E6%9C%89%E8%AF%A6%E7%BB%86%E8%AE%B2%E8%A7%A3.)
#include <iostream>
#include <fstream>
#include <string> //加入这行
using namespace std;
void multiply(const char *a,const char *b);
int main()
{
string num1,num2; // 初始状态用string来存储大数
cout<<"现在,来两个大数吧! "<<endl;
cin>>num1>>num2;
const char *p1=num1.c_str(); // 将string转为 const char *
const char *p2=num2.c_str(); // 将string转为 const char *
multiply(p1,p2);
system("pause");
return 0;
}
void multiply(const char *a,const char *b)
{
int i,j,ca,cb,*s;
ca=strlen(a);
cb=strlen(b);
s=(int *)malloc(sizeof(int)*(ca+cb)); //分配存储空间
for (i=0;i<ca+cb;i++) s[i]=0; // 每个元素赋初值0
for (i=0;i<ca;i++)
for (j=0;j<cb;j++)
s[i+j+1]+=(a[i]-'0')*(b[j]-'0');
![](http://img.wesiedu.com/upload/1/54/1541244d5d838723043ed963e17f1e4e.jpg)
for (i=ca+cb-1;i>=0;i--) // 这里实现进位操作,从低位到高位开始进位
if (s[i]>=10) //将大于10的数的进位加到高位,即i-1位,i位留余数
{
s[i-1]+=s[i]/10;
s[i]%=10;
}
char *c=(char *)malloc((ca+cb)*sizeof(char)); //分配字符数组空间,因为它比int数组省!
i=0;while(s[i]==0) i++; // 跳过头部0元素
for (j=0;i<ca+cb;i++,j++) c[j]=s[i]+'0';
c[j]='\0';
for (i=0;i<ca+cb;i++) cout<<c[i];
cout<<endl;
free(s);
}
再问: 这好像是用C++写的,希望改编为用C写。本人初学C,希望一步一步注释。
再答:
由于字数太多,存不下,又怕你看不懂,所以截成了图片,希望对你有帮助,希望你借鉴一下,本来想得到点分的,看来没戏了,但你好好看一下吧,有什么不懂得可以交流
#include <fstream>
#include <string> //加入这行
using namespace std;
void multiply(const char *a,const char *b);
int main()
{
string num1,num2; // 初始状态用string来存储大数
cout<<"现在,来两个大数吧! "<<endl;
cin>>num1>>num2;
const char *p1=num1.c_str(); // 将string转为 const char *
const char *p2=num2.c_str(); // 将string转为 const char *
multiply(p1,p2);
system("pause");
return 0;
}
void multiply(const char *a,const char *b)
{
int i,j,ca,cb,*s;
ca=strlen(a);
cb=strlen(b);
s=(int *)malloc(sizeof(int)*(ca+cb)); //分配存储空间
for (i=0;i<ca+cb;i++) s[i]=0; // 每个元素赋初值0
for (i=0;i<ca;i++)
for (j=0;j<cb;j++)
s[i+j+1]+=(a[i]-'0')*(b[j]-'0');
![](http://img.wesiedu.com/upload/1/54/1541244d5d838723043ed963e17f1e4e.jpg)
for (i=ca+cb-1;i>=0;i--) // 这里实现进位操作,从低位到高位开始进位
if (s[i]>=10) //将大于10的数的进位加到高位,即i-1位,i位留余数
{
s[i-1]+=s[i]/10;
s[i]%=10;
}
char *c=(char *)malloc((ca+cb)*sizeof(char)); //分配字符数组空间,因为它比int数组省!
i=0;while(s[i]==0) i++; // 跳过头部0元素
for (j=0;i<ca+cb;i++,j++) c[j]=s[i]+'0';
c[j]='\0';
for (i=0;i<ca+cb;i++) cout<<c[i];
cout<<endl;
free(s);
}
再问: 这好像是用C++写的,希望改编为用C写。本人初学C,希望一步一步注释。
再答:
![](http://img.wesiedu.com/upload/a/54/a54092a393af32a1be93a99d4c545f5b.jpg)