43. 字符串相乘

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

说明:

  1. num1 和 num2 的长度小于110。
  2. num1 和 num2 只包含数字 0-9
  3. num1 和 num2 均不以零开头,除非是数字 0 本身。
  4. 不能使用任何标准库的大数类型(比如 BigInteger)直接将输入转换为整数来处理

" class="notranslate">

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

说明:

  1. num1 和 num2 的长度小于110。
  2. num1 和 num2 只包含数字 0-9
  3. num1 和 num2 均不以零开头,除非是数字 0 本身。
  4. 不能使用任何标准库的大数类型(比如 BigInteger)直接将输入转换为整数来处理

JAVA


public static String multiply(String num1, String num2) {
if (num1.equals("0") || num2.equals("0")){
return "0";
}
int len1 = num1.length();
int len2 = num2.length();
int [] sums = new int[len1 + len2]; for (int i = len1 - 1; i >= 0; i--) {
int n1 = num1.charAt(i) - 48;
for (int j = len2 - 1; j >= 0; j--) {
int n2 = num2.charAt(j) - 48;
sums[i + j] += n1 * n2;
if (sums[i + j] > 9 && (i + j) != 0){
sums[i + j - 1] += sums[i + j] / 10;
sums[i + j] = sums[i + j] % 10;
}
}
}
StringBuilder builder = new StringBuilder();
for (int i = 0; i < len1 + len2 - 1; i++){
builder.append(sums[i]);
}
return builder.toString();
}

415. 字符串相加

给定两个字符串形式的非负整数&nbsp;num1num2&nbsp;,计算它们的和。

注意:

  1. num1num2&nbsp;的长度都小于 5100.
  2. num1num2 都只包含数字&nbsp;0-9.
  3. num1num2 都不包含任何前导零。
  4. 你不能使用任何內建 BigInteger 库,&nbsp;也不能直接将输入的字符串转换为整数形式。

" class="notranslate">

给定两个字符串形式的非负整数 num1num2 ,计算它们的和。

注意:

  1. num1num2 的长度都小于 5100.
  2. num1num2 都只包含数字 0-9.
  3. num1num2 都不包含任何前导零。
  4. 你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式。

JAVA


public static String strSum(String num1, String num2){
int i = num1.length() - 1;
int j = num2.length() - 1;
StringBuilder builder = new StringBuilder();
int carry = 0;
while (i >= 0 || j >= 0) {
if (i >= 0) {
carry += num1.charAt(i) - '0';
}
if (j >= 0) {
carry += num2.charAt(j) - '0';
}
builder.append((char)(carry % 10 + '0'));
carry /= 10;
i--;
j--;
}
if (carry == 1) {
builder.append('1');
}
return builder.reverse().toString();
}

最新文章

  1. 用 Express4 写一个简单的留言板
  2. windows management instrumentation服务未启动-解决脚本
  3. mysql中字段类型转换排序
  4. lag 和 lead
  5. 15款增强web体验的Javascript库
  6. HDU 5723 Abandoned country (最小生成树 + dfs)
  7. PHP判断访客是否移动端浏览器访问
  8. Struts2 一、 视图转发跳转
  9. SQL Server管理员专用连接的使用
  10. C语言中的指针
  11. 如何写好CSS系列之表单(form)
  12. find mtime参数+号,-号,不带符号的用法
  13. jquary 选择器,dom操作知识点
  14. JQUERY-自定义插件-ajax-跨域访问
  15. python全栈开发day77-博客主页
  16. eclipse is missing required source folder src/test/java
  17. ajax的type为get的时候报405错误,改成post就OK,这是为什么?老师写的get可以请求成功,我的就不行,附图
  18. Android定制争夺战 三大主流ROM横评
  19. [BZOJ4870][Shoi2017]组合数问题 dp+矩阵乘
  20. Javascript中的对象和原型(三)(转载)

热门文章

  1. ImageView 使用详解
  2. 为什么建立数据仓库需要使用ETL工具?
  3. 大话 Spring Session 共享
  4. VS调试时修改代码
  5. pythonday06数据类型(四)
  6. 分布式ID系列(5)——Twitter的雪法算法Snowflake适合做分布式ID吗
  7. 从输入URL到浏览器显示页面发生了哪些事情---个人理解
  8. 用友java后端开发面经
  9. Day 02--选题与设计(二)
  10. js中toFixed精度问题的解决办法