大数相乘(C语言) 一时失言乱红尘 2022-12-27 02:29 126阅读 0赞 大数相乘 输入两个很大的数相乘得出结果。 例如: 输入: 86164546164196136413315 14654561525131314584561 输出: 1262703643048229694819656018451010743813829715 #include<stdio.h> #include<string.h> #include<stdlib.h> #define getm(type,len) (type *)malloc(sizeof(type)*len) void copy_to(int *num, char cnum[],int len); void mult(char cnum1[], char cnum2[], int num[]); void char_to_int(char cnum1[],char cnum2[]); int *num1; int *num2; int len1; int len2; int max=0; int main() { char cnum1[100]; char cnum2[100]; int num[1000]; memset(num,0,sizeof(int)*1000); printf("请输入num1:"); gets(cnum1); printf("请输入num2:"); gets(cnum2); mult(cnum1,cnum2,num); if(num[max] == 0) { max--; } for(int i=max; i>=0; i--) { printf("%d",num[i]); } printf("\n"); return 0; } void char_to_int(char cnum1[],char cnum2[]) { len1 = strlen(cnum1); len2 = strlen(cnum2); num1 = getm(int,len1); num2 = getm(int,len2); memset(num1,0,sizeof(int)*len1); memset(num2,0,sizeof(int)*len2); copy_to(num1,cnum1,len1); copy_to(num2,cnum2,len2); } void copy_to(int *num, char cnum[],int len) { for(int i=len-1; i>=0; i--) { num[len-1-i] = cnum[i] - '0'; } } void mult(char cnum1[], char cnum2[], int num[]) { int index; int sum = 0; char_to_int(cnum1,cnum2); for(int i=0; i<len1; i++) { index = i; for(int j=0; j<len2; j++) { sum += (num1[i]*num2[j] + num[index]); num[index++] = (sum%10); sum /= 10; } while(sum) { sum += num[index]; num[index++] = (sum%10); sum /= 10; } if(max < index) { max = index; } } }
相关 大数相乘(C语言) 大数相乘 输入两个很大的数相乘得出结果。 例如: 输入: 86164546164196136413315 14654561525131314584561 一时失言乱红尘/ 2022年12月27日 02:29/ 0 赞/ 127 阅读
相关 大数相乘 一、背景 最近在看算法的时候发现了一个问题,我们都知道方法的形参是要指定类型的,假如有以下方法 public int example(int a,int b){ 傷城~/ 2022年09月30日 13:55/ 0 赞/ 209 阅读
相关 大数相乘 参考地址:[http://www.cnblogs.com/heyonggang/p/3599857.html][http_www.cnblogs.com_heyonggang_ 悠悠/ 2022年08月20日 06:29/ 0 赞/ 189 阅读
相关 【C语言】大数相乘 今天抽空复习了一下,用C语言实现的大数相乘的相关算法。 算法代码如下: <span style="font-size:18px;"> include<st 深藏阁楼爱情的钟/ 2022年08月13日 00:58/ 0 赞/ 188 阅读
相关 大数相乘 无意中看到一个华为面试题,使用代码计算[1234567891011121314151617181920\2019181716151413121110987654321][123 系统管理员/ 2022年08月11日 20:29/ 0 赞/ 194 阅读
相关 大数相乘 题目:请使用代码计算1234567891011121314151617181920\2019181716151413121110987654321。 答: ![复制代码][ Bertha 。/ 2022年08月05日 08:54/ 0 赞/ 205 阅读
相关 大数相乘 在这之前我们先来了解一下Java 中每种基本数据类型所占存储空间的大小。其中 1Byte = 8bit。 <table> <tbody> <tr> <th> 朱雀/ 2022年06月02日 02:36/ 0 赞/ 253 阅读
相关 大数相乘 设X和Y是n位的二进制整数,现在要计算X\Y的结果 将a和b分为两段,每段长均为总长的1/2, ![20180329214901958][] 拼搏现实的明天。/ 2022年05月28日 05:06/ 0 赞/ 215 阅读
相关 大数相乘 题目 编写两个任意位数的大数相乘的程序,给出计算结果。比如: > 题目描述: 输出两个不超过100位的大整数的乘积。 > 输入: 输入两个大整数,如1234567 今天药忘吃喽~/ 2022年05月23日 11:23/ 0 赞/ 336 阅读
相关 大数相乘 def fun(num1,num2): num1 type str num2 type str a = map(int, 落日映苍穹つ/ 2021年10月24日 01:48/ 0 赞/ 330 阅读
还没有评论,来说两句吧...