力扣-66. 加一

文章目录

解题思路

复制代码
根据题目可以得出此题一共有3种需要特殊判断的地方。
	1.数组元素的最后一个元素是否为9,如果是那就将此处元素置0,如果不是那就此处元素加1。按照这个逻辑将digits数组重新赋值。
	2.判断重新赋值的digits数组的首元素是否是0,如果是就需要申请一个digitsSize+1的空间来存储数组,如果不是就直接将digits数组返回,数组长度是digitsSize。

代码

c 复制代码
int* plusOne(int* digits, int digitsSize, int* returnSize) 
{
    int end = digitsSize - 1;
    int *arr = NULL;
    while(end + 1)/*end+1 是确保digits数组每一个元素都遍历到*/
    {
        /*元素为9就置0,不为9就加1*/
        if(digits[end] == 9)
        {
            digits[end] = 0;
        }
        else
        {
            digits[end] =  digits[end] + 1;
            break;
        }
        end--;
    }
    
    /*判断重新赋值后的digits数组的首元素是否是0*/
    if(0 == digits[0])/*特殊情况:需要申请的空间为digitsSize+1*/
    {
        /*arr数组为{1,0,0,0,..,0}*/
        arr = (int *)malloc(sizeof(int) * (digitsSize + 1));
        arr[0] = 1;
        memset(&arr[1], 0, sizeof(int) * digitsSize);/*除了首元素其他元素置0*/
        *returnSize =digitsSize + 1;
    }
    else/*常规情况,直接将digits数组数组返回即可*/
    {
        *returnSize =digitsSize;
        return digits;
    }

    return arr;
}
相关推荐
铉铉这波能秀4 分钟前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹16 分钟前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头2 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
老鼠只爱大米4 小时前
LeetCode经典算法面试题 #46:全排列(回溯、交换、剪枝等五种实现方案详细解析)
算法·leetcode·剪枝·回溯·全排列·stj算法
im_AMBER5 小时前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
历程里程碑5 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
pp起床5 小时前
贪心算法 | part02
算法·leetcode·贪心算法
sin_hielo5 小时前
leetcode 1653
数据结构·算法·leetcode
YuTaoShao5 小时前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法二)排序 + 二分查找
数据结构·算法·leetcode