#include "stdafx.h" #include <iostream> void multiply(char* a,char* b,char* c) { 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; for (i=0;i<ca;i++) //s[0]作为最高位,进位 for (j=0;j<cb;j++) s[i+j+1]+=(a[i]-'0')*(b[j]-'0'); for (i=ca+cb-1;i>=0;i--) //处理进位 { if (s[i]>=10) s[i-1]+=s[i]/10; s[i]%=10; } i=0; while (s[i]==0) //找出第一个非零位 i++; for (j=0;i<ca+cb;i++,j++) c[j]=s[i]+'0'; if(0 == j) //处理和0相乘时的情况 { c[0] = '0'; j++; } c[j]='\0'; free(s); } int main() { char *a="463434436547465646347676434343"; char *b="1464534165468468454"; char *c=new char[256]; multiply(a,b,c); std::cout<<c<<std::endl; }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。