这是悦乐书的第371次更新,第399篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第233题(顺位题号是989)。对于非负整数XX的数组形式是从左到右顺序的数字数组。例如,如果X = 1231,则数组形式为[1,2,3,1]

给定非负整数X的数组形式A,返回整数X + K的数组形式。例如:

输入:A = [1,2,0,0],K = 34

输出:[1,2,3,4]

说明:1200 + 34 = 1234

输入:A = [2,7,4],K = 181

输出:[4,5,5]

说明:274 + 181 = 455

输入:A = [2,1,5],K = 806

输出:[1,0,2,1]

说明:215 + 806 = 1021

输入:A = [9,9,9,9,9,9,9,9,9,9],K = 1

输出:[1,0,0,0,0,0,0,0,0,0,0]

说明:9999999999 + 1 = 10000000000

注意

  • 1 <= A.length <= 10000

  • 0 <= A [i] <= 9

  • 0 <= K <= 10000

  • 如果A.length > 1,则A[0]!= 0。

02 第一种解法

题目的意思是要我们把K(低位到高位)每一位数加到A(从后往前)中对应位上,最后输出一个List

思路:先处理K,每次拿A的个位数,使用对10取余得到,再从A中取一位数出来(从后往前),两数相加,需要判断是否有进位产生,将和添加进List中,K再除以10,切换到新的个位数,直到K等于0。处理完K后,如果A中还有数没处理完,需要再处理下,在前面处理K时遗留的进位依旧需要参与运算,直到处理完A中所有元素。最后,如果存进位的变量还有值,则需要将其添加进List中。因为处理数据是从后往前的顺序,所以需要将List反转,借助Collectionsreverse方法完成。

  1. public List<Integer> addToArrayForm(int[] A, int K) {
  2. List<Integer> result = new ArrayList<Integer>();
  3. int i = A.length-1, tem = 0;
  4. while (K > 0) {
  5. // i需要判断一次,因为A的长度可能比K的位数小
  6. int current = K%10 + (i >=0 ? A[i--] : 0) + tem;
  7. // 大于10会产生进位
  8. if (current >= 10) {
  9. current -= 10;
  10. tem = 1;
  11. } else {
  12. tem = 0;
  13. }
  14. result.add(current);
  15. K /= 10;
  16. }
  17. // 如果K已经处理完了,但是A中还有数没有处理
  18. while (i >= 0) {
  19. // 依旧需要判断进位
  20. if (A[i]+tem >= 10) {
  21. result.add(A[i]+tem-10);
  22. tem = 1;
  23. } else {
  24. result.add(A[i]+tem);
  25. tem = 0;
  26. }
  27. i--;
  28. }
  29. // 判断最高位是否存在进位
  30. if (tem != 0) {
  31. result.add(tem);
  32. }
  33. // 反转result
  34. Collections.reverse(result);
  35. return result;
  36. }

03 第二种解法

我们还可以对第一种解法再简化下。

思路:将A中每次从后往前取的数,加到K上面(K最大为10000,不存在越界问题),然后每次取K的最后一位数(借助取余),计算完后将K除以10,直到K等于0。

  1. public List<Integer> addToArrayForm2(int[] A, int K) {
  2. List<Integer> result = new ArrayList<Integer>();
  3. int i = A.length-1, tem = K;
  4. while (i >= 0 || tem > 0) {
  5. if (i >= 0) {
  6. tem += A[i--];
  7. }
  8. result.add(tem%10);
  9. tem /= 10;
  10. }
  11. // 反转result
  12. Collections.reverse(result);
  13. return result;
  14. }

04 小结

算法专题目前已连续日更超过七个月,算法题文章239+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.989-数组形式的整数做加法(Add to Array-Form of Integer)的更多相关文章

  1. [Swift]LeetCode989. 数组形式的整数加法 | Add to Array-Form of Integer

    For a non-negative integer X, the array-form of X is an array of its digits in left to right order.  ...

  2. 52. 不用+、-、×、÷做加法[add two numbers without arithmetic]

    [本文链接] http://www.cnblogs.com/hellogiser/p/add-two-numbers-without-arithmetic.html [题目] 写一个函数,求两个整数的 ...

  3. 力扣(LeetCode)整数形式的整数加法 个人题解

    对于非负整数 X 而言,X 的数组形式是每位数字按从左到右的顺序形成的数组.例如,如果 X = 1231,那么其数组形式为 [1,2,3,1]. 给定非负整数 X 的数组形式 A,返回整数 X+K 的 ...

  4. 剑指offer 65. 不用加减乘除做加法(Leetcode 371. Sum of Two Integers)

    剑指offer 65. 不用加减乘除做加法(Leetcode 371. Sum of Two Integers) https://leetcode.com/problems/sum-of-two-in ...

  5. 循序渐进做项目系列(1):最简单的C/S程序——让服务器来做加法

    (本文是专门针对未接触过C/S开发的初学者而写的,C/S开发高手请自动忽略啊~~) 还在写“Hello world!”式的单机程序吗?还在各种拖控件吗?是否自己都觉得有点low呢?来个质的飞跃吧!看看 ...

  6. 最简单的C/S程序——让服务器来做加法

    还在写“Hello world!”式的单机程序吗?还在各种拖控件吗?是否自己都觉得有点low呢?来个质的飞跃吧!看看怎么让服务器帮咱做加法! 所谓C/S程序就是Client/Server程序,自然既包 ...

  7. [LeetCode] 数学计算模拟类问题:加法,除法和幂,注意越界问题。题 剑指Offer,Pow(x, n) ,Divide Two Integers

    引言 数学计算的模拟类题目,往往是要求实现某种计算(比如两数相除),实现的过程中会有所限定,比如不允许乘法等等. 这类题目首先要注意计算过程中本身的特殊情况.比如求相除,则必须首先反映过来除数不能为0 ...

  8. POJ2155/LNSYOJ113 Matrix【二维树状数组+差分】【做题报告】

    这道题是一个二维树状数组,思路十分神奇,其实还是挺水的 题目描述 给定一个N∗NN∗N的矩阵AA,其中矩阵中的元素只有0或者1,其中A[i,j]A[i,j]表示矩阵的第i行和第j列(1≤i,j≤N)( ...

  9. 【剑指Offer】不用加减乘除做加法 解题报告(Java)

    [剑指Offer]不用加减乘除做加法 解题报告(Java) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-interviews 题 ...

随机推荐

  1. iOS中为控件设置颜色渐变和透明度渐变

    项目中用到地图设置渐变色,查找资料找到两种方法:一种设置颜色,一种设置透明度: //为颜色设置渐变效果: UIView *view = [[UIView alloc] initWithFrame:CG ...

  2. springboot+elasticsearch 报错

    错误1: .d.e.r.s.AbstractElasticsearchRepository : failed to load elasticsearch nodes : org.elasticsear ...

  3. 利用docker 部署项目

    docker_tomcat_jdk 7.0 1.6 app admin && api 1.yum install docker 2.service docker start 3.创建文 ...

  4. 关于数字加载的动画 jquery

    这是关于数字加载的一个动画,从0开始变化到设置的数字,依赖于jquery,效果如下所示 当然,数字要显示的位数是可以设置的,默认是全部位数的数字,设置显示位数可以直接传递参数,例如: html文件为: ...

  5. noip模拟总结

    先讲讲今天的比赛, T1: 看着很水,在草稿纸上画了一下,发现其实并不简单, 于是先去打第二题, 最后半个小时实在是一点头绪也没有, 打了个状压dp 70分(暴力分真多). T2: 把样例画出来模拟一 ...

  6. CSS3做出条纹大背景

    ㈠实现不等宽背景条纹   实现如上图所示的效果,代码如下: <!DOCTYPE html> <html lang="en"> <head> &l ...

  7. C语言写数据库(二)

    简单的实现增删查改的操作后,实现了一个先读写其中一个表的某两项内容,再把相关字符段写入到另外一张表中去.涉及到查询和插入两个步骤. 其中还涉及到汉字的读写和插入,会有字符的操作产生乱码.所以要先保证m ...

  8. 工具类--BeanUtils----Bean转换工具

    package com.zhouyy.netBank.util; import java.beans.PropertyDescriptor; import java.lang.reflect.Fiel ...

  9. 前后端分离,get请求导出

    [HttpGet] public HttpResponseMessage Export(string obj) { string eventType = string.Empty; string ex ...

  10. HashMap、Hashtable、HashSet三种hash集合的区别

    转载:http://www.cnblogs.com/lzrabbit/p/3721067.html#h1 HashMap和Hashtable的区别 两者最主要的区别在于Hashtable是线程安全,而 ...