当前位置:网站首页>Leetcode刷题——字符串相加相关题目(415. 字符串相加、面试题 02.05. 链表求和、2. 两数相加)
Leetcode刷题——字符串相加相关题目(415. 字符串相加、面试题 02.05. 链表求和、2. 两数相加)
2022-08-02 19:23:00 【lonelyMangoo】
概述
这三道题都是字符串相加相关的,后面的是链表,本质还是字符串相加。
415. 字符串相加
想看看题目
字符串相加
这道题是我上次面试遇到的,是简单题,但是面试官不让我debug,而且写的时候出现了好几个问题也没发现,步骤冗余等等,所以现在做一下总结。
这道题本质上就是一位一位相加,然后进位。
先看看我面试时候写的
public String addStrings(String num1, String num2) {
int pre=0;
//表示当前位的数
// int now = 0;
StringBuilder res = new StringBuilder();
int len1 =num1.length()-1;
int len2 = num2.length()-1;
while (len1>=0 && len2>=0){
Integer sNum1 = new Integer(num1.substring(len1, len1 + 1));
Integer sNum2 = new Integer(num2.substring(len2, len2 + 1));
int tpsum = sNum1+sNum2+pre;
pre=tpsum/10;
tpsum=tpsum%10;
res.append(tpsum);
len1--;
len2--;
}
while (len1>=0){
Integer sNum1 = new Integer(num1.substring(len1, len1 + 1));
int tpsum = sNum1+pre;
pre =tpsum/10;
tpsum=tpsum%10;
res.append(tpsum);
len1--;
}
while (len2>=0){
Integer sNum2 = new Integer(num2.substring(len2, len2 + 1));
int tpsum = sNum2+pre;
pre =tpsum/10;
tpsum=tpsum%10;
res.append(tpsum);
len2--;
}
if(pre == 1){
res.append(pre);
}
return res.reverse().toString();
}

当时出现了好几个问题
- while里面忘记len忘记大于等于0了,当时没看出来
- 当时有一段是复制的,1、2没改
- 有很多冗余的变量,压根可以不需要
- 三个while可以合并成一个,代码冗余太严重
- 获取单个元素方法效率很差
改进之后的代码:
public String addStrings(String num1, String num2) {
int pre = 0;
StringBuilder sb = new StringBuilder();
int len1 = num1.length()-1;
int len2 = num2.length()-1;
int sum;
while (len1>=0 || len2>=0){
sum=0;
if(len1>=0){
sum += num1.charAt(len1)-'0';
len1--;
}
if(len2>=0){
sum += num2.charAt(len2)-'0';
len2--;
}
sum+=pre;
pre=sum/10;
sum=sum%10;
sb.append(sum);
}
if(pre == 1){
sb.append(1);
}
return sb.reverse().toString();
}
这里最后一个判断是因为最后一次的进位没有计算。
链表相加
除了是链表以外,都是一样的。
结尾用一个新链表尾插法进行
代码:
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
int pre= 0;
//使用头插法
ListNode listNode = new ListNode(0);
ListNode res = listNode;
int sum;
while (l1!=null || l2!=null){
sum=0;
if(l1!=null){
sum+=l1.val;
l1=l1.next;
}
if(l2!=null){
sum+=l2.val;
l2=l2.next;
}
sum+=pre;
pre =sum/10;
sum=sum%10;
ListNode tp = new ListNode(sum);
// tp.next=listNode.next;
// listNode.next=tp;
listNode.next=tp;
listNode=listNode.next;
}
if(pre == 1){
ListNode tp = new ListNode(1);
listNode.next=tp;
// tp.next=listNode.next;
// listNode.next=tp;
}
return res.next;
}


边栏推荐
猜你喜欢

What is a Field Service Management System (FSM)?what is the benefit?

Electron使用指南之初体验

平稳发展 | 西欧地区手游玩家的数据和洞察

Detailed explanation of common examples of dynamic programming

元宇宙001 | 情绪无法自控?元宇宙助你一臂之力

【LeetCode】118. 杨辉三角 - Go 语言题解

【C语言刷题】Leetcode238——除自身以外数组的乘积

Caldera(一)配置完成的虚拟机镜像及admin身份简单使用
分享一个 web 应用版本监测 (更新) 的工具库

ShapeableImageView 的使用,告别shape、三方库
随机推荐
SQL server有什么认证吗?
openlayers版本更新差别
【Psychology · Characters】Issue 1
【软件工程导论】软件工程导论笔记
让你的应用完美适配平板
动态折线图,制作原来是这么简单
银保监会:人身险产品信披材料应由保险公司总公司统一负责管理
Caldera(一)配置完成的虚拟机镜像及admin身份简单使用
简单有效又有用的关闭antimalware service executable的方法·备份记录
基于OpenGL的冰川与火鸟(光照计算模型、视景体、粒子系统)
[安洵杯 2019]easy_web
解析Collection接口中的常用的被实现子类重写的方法
7.22 - 每日一题 - 408
Therapy | How to Identify and Deal with Negative Thoughts
es 读流程源码解析
Caldera(二)高级实战
快速掌握jmeter(一)——实现自动登录与动态变量
Detailed explanation of common examples of dynamic programming
Gradle系列——Gradle的build.gradle文件详情,项目发布(基于Gradle文档7.5)day3-3
NC | Structure and function of soil microbiome reveal N2O release from global wetlands