给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。 最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。 你可以假设除了整数 0 之外,这个整数不会以零开头。 复制代码
示例:
输入: [1,2,3] 输出: [1,2,4] 解释: 输入数组表示数字 123。 输入: [4,3,2,1] 输出: [4,3,2,2] 解释: 输入数组表示数字 4321。 复制代码
思考:
将原数组从后向前遍历,若最后一个元素即个位数字小于9,直接+1就行。 若大于9,则要向前进位,当前位直接赋值为0,下次循环将倒数第二位+1。 从后向前以此类推,遇到小于9的直就接+1返回结果。 否则直到循环结束则说明原数是“99”、“999”类似这样的,此时加一结果就是“100”、“1000”这样比原来多一位的。 则新建一个比原数组长度多一的数组,并且将数组第0个赋值为1返回即可。 复制代码
实现:
class Solution {
public int[] plusOne(int[] digits) {
int n = digits.length;
for(int i = n-1; i >= 0; i --) {
if(digits[i] < 9) {
digits[i]++;
return digits;
}
digits[i] = 0;
}
int[] result = new int[n+1];
result[0] = 1;
return result;
}
}复制代码
以上所述就是小编给大家介绍的《LeetCode每日一题: 加一(No.66)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机程序设计艺术
Donald E.Knuth / 黄林鹏 / 机械工业出版社 / 2010-8 / 69.00元
《计算机程序设计艺术(第4卷·第0册):组合算法与布尔函数概论(双语版)》是《计算机程序设计艺术,第4卷:组合算法》的第0册。《计算机程序设计艺术(第4卷·第0册):组合算法与布尔函数概论(双语版)》介绍了组合搜索历史和演化,涉及组合搜索技术的理论和实践应用,探究了布尔函数相关的所有重要问题,考察了如何最有效地计算一个布尔函数的值的技术。本册是《计算机程序设计艺术的》第7章,即组合搜索一长篇宏论的......一起来看看 《计算机程序设计艺术》 这本书的介绍吧!