每日算法之三十四:Multiply Strings
大数相乘,分别都是用字符串表示的两个大数。求相乘之后的结果表示。
首先我们应该考虑一下測试用例会有哪些,先准备測试用例对防御性编程会有比較大的帮助。可以考虑一些极端情况。有以下几种用例:
1)"0","0"
2)"0","879127346783" 当中一个是零
3)"as234","123343" 存在非法字符
4)"000000000000001234","2546" 存在零前缀。有冗余计算
大概就这么多吧。
要想实现大数乘法。必定先实现大数相加和一个大数和一个数字相乘。
这样大数相乘就行切割迭代计算。
以下是算法,自己写的。可能存在冗余。
<span style="font-size:14px;">class Solution {
public:
string subTwoString(string num1,string num2) //大数相加
{
string result = "";
int i = num1.length()-1;
int j = num2.length()-1;
int plus = 0;//进位
while(i>=0 && j>=0)
{
int temp = num1[i]-'0' + num2[j]-'0' + plus;//不能忘掉进位
result =char(temp%10+'0')+ result;
plus = temp/10;
i--;j--;
}
if(i>=0)//一种一个没有加完。不全结果,当然还有进位
{
while(i>=0)
{
int temp = num1[i]-'0' + plus;
result =char(temp%10+'0')+ result;
plus = temp/10;
i--;
}
}
if(j>=0)
{
while(j>=0)
{
int temp = num2[j]-'0' + plus;
result =char(temp%10+'0')+ result;
plus = temp/10;
j--;
}
}
if(plus != 0)//最后进位不为零是要在结果头部加上
result = char(plus+'0')+result;
return result;
}
string multi(string num1,int num)//大数和一位数字相乘
{
int len = num1.length()-1;
int plus = 0;
string result = "";
while(len>=0)
{
int temp = (num1[len] - '0') * num + plus;//plus刚開始是忘掉的,也不能写在括号内,跟加法不同
result = char(temp%10+'0') + result;
plus = temp/10;
len--;
}
if(plus != 0)
result = char(plus+'0') + result;
return result;}
string multiply(string num1, string num2) {//大数相乘
if(num1.length() == 0 || num2.length() ==0)
return 0;
if(num1 == "0"|| num2 == "0")
return "0";
string result = "";
int len1 = num1.length();
int len2 = num2.length();
for(int i = 0;i<len1;i++)
if(!isdigit(num1[i]))//是否存在数字
return 0;
for(int j = 0;j<len2;j++)
if(!isdigit(num2[j]))
return 0;
for(int k = len2-1;k>=0;k--)
{
string temp = multi(num1,num2[k]-'0');
for(int l = len2-k-1;l>0;l--)
temp = temp + "0";
result = subTwoString(result,temp);
}
return result;
}
};</span>
以下是还有一种方法。不是依照手算乘法计算的,使用了辅助数组利用特点写的:
思路:假设两个大数分别为m和n位,那么结果最多为m+n位,或者为m+n-1位(最后不存在进位)。比方123和23相乘。
| 0 | 0 | 3 | 6 | 9 |
| 0 | 2 | 4 | 6 | 0 |
| 0 | 2 | 7 | 12 | 9 |
| 0 | 2 | 8 | 2 | 9 |
以下做一下解释,第一行是123和3相乘的结果,第二行是2和123相乘的结果。
顺序前移了一位。第三行是把之前的计算结果相加。第四行是从后往前
求进位,知道最開始。
最后。再把他们转化成字符串就可以。
<span style="font-size:14px;">string multiply(string num1, string num2) {
if(num1=="0" || num2=="0") return "0";
int l1 = num1.length(), l2 = num2.length();
int* n1 = new int[l1];
int* n2 = new int[l2];
int* res = new int[l1+l2];
memset(res,0,sizeof(int)*(l1+l2));
for(int i=0; i<l1; ++i)
n1[i] = num1[i] - '0';
for(int i=0; i<l2; ++i)
n2[i] = num2[i] - '0';
for(int i=0; i<l1; ++i)
for (int j=0; j<l2; ++j)
res[i+j+1] += n1[i]*n2[j];
string ss = "";
for (int k=l1+l2-1; k>=0; --k){
if(k>0) res[k-1] += res[k]/10;
res[k] %= 10;
ss = char(res[k]+'0')+ss;
}
ss = ss[0]=='0'? ss.substr(1):ss;
//return ss.empty()?
"0":ss;
return ss;
}</span>每日算法之三十四:Multiply Strings的更多相关文章
- 每日算法之三十八:Anagrams
Given an array of strings, return all groups of strings that are anagrams. Note: All inputs will be ...
- 每日算法之三十五:Wildcard Matching
模式匹配的实现,'?'代表单一字符,'*'代表随意多的字符.写代码实现两个字符串是否匹配. Implement wildcard pattern matching with support for ' ...
- 经典算法题每日演练——第十四题 Prim算法
原文:经典算法题每日演练--第十四题 Prim算法 图论在数据结构中是非常有趣而复杂的,作为web码农的我,在实际开发中一直没有找到它的使用场景,不像树那样的频繁使用,不过还是准备 仔细的把图论全部过 ...
- Java数据结构和算法(十四)——堆
在Java数据结构和算法(五)——队列中我们介绍了优先级队列,优先级队列是一种抽象数据类型(ADT),它提供了删除最大(或最小)关键字值的数据项的方法,插入数据项的方法,优先级队列可以用有序数组来实现 ...
- VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
上一节讲了标签控件Tab Control以后,常用控件的内容就全部讲完了,当然并没有包括所有控件,主要是一些很常用很重要的控件.本节开始鸡啄米将为大家讲解菜单的概念及使用. 菜单简介 菜单在界面设计中 ...
- GUI学习之三十四——QSS样式表
今天是一个大课题:QSS样式表 一.概念: QSS是Qt Style Sheet——Qt样式表,是用来自定义控件外观的一种机制;可以把他类比成CSS,但是不及其功能强大. 二.使用: 我们做一个模板, ...
- OpenCV-Python 图像分割与Watershed算法 | 三十四
目标 在本章中, 我们将学习使用分水岭算法实现基于标记的图像分割 我们将看到:cv.watershed() 理论 任何灰度图像都可以看作是一个地形表面,其中高强度表示山峰,低强度表示山谷.你开始用不同 ...
- 爪哇国新游记之三十四----Dom4j的XPath操作
Dom4j是Java访问XML的利器之一,另一个是JDom.记得当年因为粗掌握点JDomAPI但项目要求使用Dom4j还闹一阵情绪,现在看来真是没必要,只花一些时间成本就进去一个新世界绝对是值得做的一 ...
- 每日算法之三十三:Trapping Rain Water
这是一个非常有意思的问题,求解最大容积问题,值得动脑筋想一想. 原题例如以下: Given n non-negative integers representing an elevation map ...
随机推荐
- HttpException (0x80004005): 无法连接到 SQL Server 会话数据库
ASP.NET 项目运行时出现错误提示:[HttpException (0x80004005): 无法连接到 SQL Server 会话数据库.] ,后排查问题发现是由于项目的Session模式是使用 ...
- 线性SVM分类器实战
1 概述 基础的理论知识参考线性SVM与Softmax分类器. 代码实现环境:python3 2 数据处理 2.1 加载数据集 将原始数据集放入"data/cifar10/"文件夹 ...
- vue-cli 构建项目
1.安装vue-cli和webpack npm install webpack -g npm install vue-cli -g 2.vue-cli初始化项目 vue init webpack-si ...
- 浪潮云+/云加 App 智能化的企业移动办公平台官网下载地址
上Google?Facebook? 点这里: 手机端:https://ecm.inspur.com/ 桌面端:https://ecm.inspuronline.com/
- [转]WPF中Binding的技巧
在WPF应用的开发过程中Binding是一个非常重要的部分. 在实际开发过程中Binding的不同种写法达到的效果相同但事实是存在很大区别的. 这里将实际中碰到过的问题做下汇总记录和理解. 1. so ...
- mysql函数,语法
转自:http://www.cnblogs.com/kissdodog/p/4168721.html MySQL数据库提供了很多函数包括: 数学函数: 字符串函数: 日期和时间函数: 条件判断函数: ...
- Mysql--数据表碎片优化方法
碎片产生原因: 大量批量插入和删除操作数据库,基于线性表的顺序存储结构的特点,出现了大量的空间碎片.一.优化步骤: 1.查看整库的情况 2.方便优化 3.整库所有表, 包含行数 索引长度 碎片空间 二 ...
- JS实现数据双向绑定
本文参考https://www.cnblogs.com/tianhaining/p/8425345.html 首先先说个面试题哈,就是vue中的v-model是如何实现双向数据绑定的咳咳,下面开始背诵 ...
- 深入protoBuf
ProtoBuf 官方文档翻译 [翻译] ProtoBuf 官方文档(一)- 开发者指南 [翻译] ProtoBuf 官方文档(二)- 语法指引(proto2) [翻译] ProtoBuf 官方文档( ...
- httpclient遇到java.net.URISyntaxException: Illegal character in scheme name at index 0:
正准备按照大佬的解决办法处理, 看会一条回复,说url有空格 检查了一下,还真是有空格 去除url中的空格,问题解除