PlusOne

问题描述:一个数组每一位代表一个数字的每一位。数字高位在数组的低位。求数字加1后得到新数组。

算法分析:要从数组的高位到低位进行遍历。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
public class PlusOne
{
    public int[] plusOne(int[] digits)
    {
        int len = digits.length;
        int carry = 0;
        digits[len-1] += 1;
        if(digits[len-1] >= 10)
        {
            digits[len-1] = digits[len-1]-10;
            carry = 1;
        }
        for(int i = len-2; i >=0 ; i --)
        {
            digits[i] += carry;
            if(digits[i] >= 10)
            {
                digits[i] = digits[i] - 10;
                carry = 1;
            }
            else
            {
                carry = 0;
            }
        }
        if(carry == 1)
        {
            int[] array = new int[len+1];
            for(int i = len; i > 0; i --)
            {
                array[i] = digits[i-1];
            }
            array[0] = 1;
            return array;
        }
        else
        {
            return digits;
        }
    }
     
    public int[] plusOne2(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[] array = new int[n+1];
        array[0] = 1;
        return array;
    }
}

 

posted @   32ddd  阅读(119)  评论(0编辑  收藏  举报
编辑推荐:
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
阅读排行:
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法
· Vite CVE-2025-30208 安全漏洞
点击右上角即可分享
微信分享提示