大数相乘 悠悠 2022-08-20 06:29 189阅读 0赞 参考地址:[http://www.cnblogs.com/heyonggang/p/3599857.html][http_www.cnblogs.com_heyonggang_p_3599857.html] 代码如下: /***************************************************************************** Prototype : multiply Description : 两个任意长度的长整数相乘, 输出结果 Input Param : const std::string strMultiplierA 乘数A const std::string strMultiplierB 乘数B Output : std::string strRst 乘法结果 Return Value : int 0 正确 -1 异常 *****************************************************************************/ int multiply(const std::string strMultiplierA, const std::string strMultiplierB, std::string &strRst) { if (strMultiplierA.length() == 0 || strMultiplierB.length() == 0) { return -1; } /* 在这里实现功能 */ vector<int> vecA, vecB, vecC; string strA = strMultiplierA; int i = 0, j = 0; /*将字符串转换为数字并翻转*/ /*将字符串转换为数字并翻转*/ for (i = strA.size() - 1; i >= 0; i--) { vecA.push_back(strA[i] - '0'); } for (i = strMultiplierB.size() - 1; i >= 0; i--) { vecB.push_back(strMultiplierB[i] - '0'); } vecC.resize(vecA.size() + vecB.size()); /**逐位相乘*/ for (i = 0; i < vecA.size(); i++) { for (j = 0; j < vecB.size(); j++) { vecC[i + j] += vecA[i] * vecB[j]; } } /*消除进位*/ for (i = vecC.size() - 1; i >= 0; i--) { if (vecC[i] != 0) { break; } else { vecC.pop_back(); } } int c = 0; for (i = 0; i < vecC.size(); i++) { vecC[i] += c; c = vecC[i] / 10; vecC[i] = vecC[i] % 10; } if (c != 0) { vecC.push_back(c); } /*将计算结果转换为字符串并翻转*/ for (i = 0; i < vecC.size(); i++) { strRst.push_back(char(vecC[i] + '0')); } reverse(strRst.begin(), strRst.end()); return 0; } [http_www.cnblogs.com_heyonggang_p_3599857.html]: http://www.cnblogs.com/heyonggang/p/3599857.html
相关 大数相乘 void mul(string a, string b) { int max = 0; int c[1000] = {0}; in r囧r小猫/ 2022年12月04日 08:47/ 0 赞/ 21 阅读
相关 大数相乘 一、背景 最近在看算法的时候发现了一个问题,我们都知道方法的形参是要指定类型的,假如有以下方法 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 赞/ 190 阅读
相关 大数相乘 [用分治法实现大数乘法,加法,减法(java实现)][java] 大数乘法即多项式乘法问题,求A(x)与B(x)的乘积C(x),朴素解法的复杂度O 小咪咪/ 2022年08月19日 15:12/ 0 赞/ 185 阅读
相关 大数相乘 无意中看到一个华为面试题,使用代码计算[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 阅读
还没有评论,来说两句吧...