[leetcode]multiply-strings java代码
题目:
Given two numbers represented as strings, return multiplication of the numbers as a string.
Note: The numbers can be arbitrarily large and are non-negative.
给两个用字符串表示的数字,求它们的乘积。
注意:数字非负,且可以无限大
————————————————————————
之前未考虑数字可以无限大的情况,采用的方法是 将字符串转化为数字,然后相乘,将乘积再次转化为字符串 输出,
最后发现只能通过一部分的测试用例,对于超过long类型表示范围的数字,无法通过。
-----------------------------------------------------
方法思想:根据乘法的演算过程
------------------------------------------
代码:(在牛客网上可以ac,但是leetcode有个用例过不去,超时问题)
public class Solution {
public String multiply(String num1, String num2){
if(num1.equals("0")|| num2.equals("0"))
return "0";
if(num1.charAt(0) == '-' || num2.charAt(0) == '-')
return "false";
int len_num1,len_num2;
len_num1 = num1.length();
len_num2 = num2.length();
String [] sing_mul = new String[len_num2];
int maxLen_sing = 0;
for(int z=0; z<len_num2; z++) //初始化
sing_mul[z] = "";
int times = 0;
//被乘数*乘数 --> 返回是字符串数组sing_mul,每一个元素是某个乘数位*被乘数的结果。
for(int i=len_num2-1; i>=0; i--){
int num2Cur = Integer.parseInt(String.valueOf(num2.charAt(i))); //乘数的某一位
int add = 0;
String temp = "";
//某个乘数位*被乘数 ---> 返回是一个字符串
for(int j=len_num1-1; j>=0; j--){ //遍历被乘数的每一位
int num1Cur = Integer.parseInt(String.valueOf(num1.charAt(j)));
int mulCur = num1Cur * num2Cur + add;
temp += String.valueOf(mulCur%10);
add = mulCur/10;
}
if(add != 0){
temp += String.valueOf(add);
}
StringBuffer sb_temp = new StringBuffer(temp);
StringBuffer temp_rev = sb_temp.reverse();
String str_temp ;
str_temp = temp_rev.toString();
//末尾补充"0";
for (int z=0; z<times; z++)
str_temp += "0";
sing_mul[i] = str_temp;
times ++;
//maxLen_sing --> 字符串数组sing_mul中元素的最大长度
if(sing_mul[i].length()>maxLen_sing)
maxLen_sing = sing_mul[i].length();
}
//将字符串数组中的所有元素相加。
String result = sing_mul[0];
for(int z=1; z<len_num2; z++){
int len_res = result.length();
//给短的字符串前补充"0".
if(sing_mul[z].length()<len_res){ //字符串前部进行填充
//先反转字符串,补"0",再次反转字符串。
StringBuffer sb_z = new StringBuffer(sing_mul[z]);
String sb_z_str = sb_z.reverse().toString();
for(int w=0; w<(len_res-sing_mul[z].length());w++)
sb_z_str += "0";
StringBuffer sb_temp = new StringBuffer(sb_z_str);
sing_mul[z] = sb_temp.reverse().toString();
}
int add_ = 0;
String temp_str = "";
for(int i=len_res-1; i>=0; i--){
int n1 = Integer.parseInt(String.valueOf(result.charAt(i)));
int n2 = Integer.parseInt(String.valueOf(sing_mul[z].charAt(i)));
int tep = n1+n2+add_;
add_ = tep/10;
temp_str += tep%10;
}
if(add_ != 0){
temp_str += String.valueOf(add_);
}
StringBuffer sb_temp_str = new StringBuffer(temp_str);
result = sb_temp_str.reverse().toString();
}
return result;
}
public static void main(String [] args){
Solution mulStr = new Solution();
String result = mulStr.multiply("9133","0");
System.out.print(result);
}
}
代码解释:
1. num1为被乘数,num2为乘数,用乘数的每一位去乘被乘数,得到一个字符串---》最终会得到字符串数组sig_mul,其中包含乘数位数个字符串
(注意:除了最后一个乘数位,其余的乘数位和被乘数相等得到的字符串应该在末尾补充相应位数的“0”)
2. sig_mul[0]中的字符串是最长的,因此result = sig_mul[0]
3. 每次使用result和sig_mul中的元素相加(1<=i<sig_mul.length)
(注意:每次相加之后的位数都会变化,但是以result的位数为准,因为它始终表示最长的位数)
(注意:每次使用sig_mul中的元素和result相加时,当sig_mul[i]的位数<result的位数时,应该给sig_mul[i]前补充相应位数的“0”,从而使得两个相加的字符串的位数相等,可以进行相加)
4. 在这个过程中会频繁的用到字符串reverse。
(因为每次相加或者相乘都是从字符串的末尾开始的,而正确的字符串应该是相乘或者相加结果的反转的字符串)
文中转化的方式是 String 转化 StringBuffer --》利用StringBuffer.reverse() --》StringBuffer 转化String
-----------------------------------------
部分问题未解决,后面更新。
[leetcode]multiply-strings java代码的更多相关文章
- LeetCode: Multiply Strings. Java
Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ...
- LeetCode: Multiply Strings 解题报告
Multiply StringsGiven two numbers represented as strings, return multiplication of the numbers as a ...
- [LeetCode] Multiply Strings 字符串相乘
Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ...
- [leetcode]Multiply Strings @ Python
原题地址:https://oj.leetcode.com/problems/multiply-strings/ 题意: Given two numbers represented as strings ...
- 43. Multiply Strings (JAVA)
Given two non-negative integers num1 and num2represented as strings, return the product of num1 and ...
- LeetCode:Multiply Strings
题目链接 Given two numbers represented as strings, return multiplication of the numbers as a string. Not ...
- [Leetcode] Multiply strings 字符串对应数字相乘
Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ...
- leetcode面试准备:Multiply Strings
1 题目 Given two numbers represented as strings, return multiplication of the numbers as a string. Not ...
- [LeetCode] 415 Add Strings && 67 Add Binary && 43 Multiply Strings
这些题目是高精度加法和高精度乘法相关的,复习了一下就做了,没想到难住自己的是C++里面string的用法. 原题地址: 415 Add Strings:https://leetcode.com/pro ...
- LeetCode解题报告—— Combination Sum & Combination Sum II & Multiply Strings
1. Combination Sum Given a set of candidate numbers (C) (without duplicates) and a target number (T) ...
随机推荐
- 作业要求20181204-7 Final阶段第1周/共1周 Scrum立会报告+燃尽图 02
作业要求参见https://edu.cnblogs.com/campus/nenu/2018fall/homework/2481 版本控制地址https://git.coding.net/lglr20 ...
- Alpha版本BUG BASH
在本次软件开发的第一轮迭代中,我们团队遇到了很多问题.首先是和学长联系不上导致拿到项目前一版本的代码的时间延后了一个星期. 拿到代码后发现由于安装环境的问题代码无法移植.在这一阶段我们就耗费了大量的时 ...
- Teamproject --人员职责
职责分配: 初步分工如下: PM:林豪森 Dev:宋天舒 张迎春 黄漠源 刘翔宇 叶露婷 旦增晋美 黄敬博 Test:林豪森 宋天舒 张迎春 刘翔宇 经过团队的讨论,认为对于职责的分配,并不存在绝对的 ...
- bata7
目录 组员情况 组员1:胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:恺琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:何宇恒 组员11:刘一好 展示组内最新 ...
- Android笔记-5-EditText密码和Checkbox二选一
EditText密码:明文和密文 密文: public class MainActivity extends Activity { private EditText password = null; ...
- week_2 四则运算
coding地址: https://git.coding.net/lvgx/week_2.git 一. 需求分析 1.接收一个输入参数n,然后随机产生n道加减乘除(分别使用符号+-*÷来表示)练习题 ...
- 《软件工程和Python》第0周作业1
写在前面的话 欢迎大家开始一段新的课程学习!从开博客开始吧.每次博客作业都会有评分,计入总成绩哦. 1. 截止日期 本次作业的提交截止时间:见老师要求 2. 作业要求 (1)建立个人技术博客和 ...
- 软工之404 Note Found队选题报告
目录 NABCD分析引用 N(Need,需求): A(Approach,做法): B(Benefit,好处): C(Competitors,竞争): D(Delivery,交付): 初期 中期 个人贡 ...
- YFCC 100M数据集分析笔记
--从YFCC 100M数据集中筛选出Geo信息位于中国的数据集 1.YFCC 100M简介 YFCC 100M数据库是2014年来基于雅虎Flickr的影像数据库.该库由1亿条产生于2004年至20 ...
- 浏览器播放rtmp流
我是利用flash插件实现的,需要以下几个文件: flowplayer-3.2.8.min.js flowplayer-3.2.18.swf flowplayer.rtmp-3.2.8.swf flo ...