66. 加一 (编程基础0到1)(Leetcode)

题目:

给定一个表示 大整数 的整数数组 digits,其中 digits[i] 是整数的第 i 位数字。这些数字按从左到右,从最高位到最低位排列。这个大整数不包含任何前导 0

将大整数加 1,并返回结果的数字数组。
示例 1:

复制代码
输入:digits = [1,2,3]
输出:[1,2,4]
解释:输入数组表示数字 123。
加 1 后得到 123 + 1 = 124。
因此,结果应该是 [1,2,4]。

示例 2:

复制代码
输入:digits = [4,3,2,1]
输出:[4,3,2,2]
解释:输入数组表示数字 4321。
加 1 后得到 4321 + 1 = 4322。
因此,结果应该是 [4,3,2,2]。

示例 3:

复制代码
输入:digits = [9]
输出:[1,0]
解释:输入数组表示数字 9。
加 1 得到了 9 + 1 = 10。
因此,结果应该是 [1,0]。

题目来源:

https://leetcode.cn/problems/plus-one/description/?envType=study-plan-v2&envId=programming-skills

思路分析:

自己写的 没通过。后面看的题解。方法很厉害 来学习一下。

num+=digits[i]*(pow(10,n-i-1)); //我是这句话没通过

代码实现:

这个是自己写的:

cpp 复制代码
class Solution {
public:
    vector<int> plusOne(vector<int>& digits) {
        int n=sizeof(digits);
        int num=0;
        for(int i=0;i<n;i++){
         num+=digits[i]*(pow(10,n-i-1));   
        }
        num=num+1;
        //数组转换成数组
        if(num/pow(10,n)==0){//说明没有进位
            for(int i=0;i<n;i++){
                digits[n-1-i]=num%10;
                num=num/10;
            }
        }
        else{
            for(int i=0;i<n+1;i++){//发生进位
                digits[n-i]=num%10;
                num=num/10;
            }
        }
       return digits;
    }
};

这个是借鉴别人的:

cpp 复制代码
class Solution  {

public:

    vector<int> plusOne(vector<int>& digits) {

        for(int i=digits.size()-1; i>=0; i--)

        {

            digits[i]++;

            if(digits[i] == 10)  digits[i] = 0;

            else  return digits;

        }

        digits.insert(digits.begin(), 1);

        return digits;

    }

};

作者:无邪
链接:https://leetcode.cn/problems/plus-one/solutions/367391/si-lu-chao-ji-jian-dan-gong-da-jia-can-kao-by-wuxi/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

题目心得:

  • 数组中 insert(place,n)函数的使用; //将数组中指定的place处的元素+n
  • 例子 digits.insert(digits.begin(), 1);
相关推荐
AI机器学习算法4 小时前
深度学习模型演进:6个里程碑式CNN架构
人工智能·深度学习·cnn·大模型·ai学习路线
Ztopcloud极拓云视角4 小时前
从 OpenRouter 数据看中美 AI 调用量反转:统计口径、模型路由与多云应对方案
人工智能·阿里云·大模型·token·中美ai
AI医影跨模态组学4 小时前
如何将深度学习MTSR与膀胱癌ITGB8/TGF-β/WNT机制建立关联,并进一步解释其与患者预后及肿瘤侵袭、免疫抑制的生物学联系
人工智能·深度学习·论文·医学影像
搬砖的前端5 小时前
AI编辑器开源主模型搭配本地模型辅助对标GPT5.2/GPT5.4/Claude4.6(前端开发专属)
人工智能·开源·claude·mcp·trae·qwen3.6·ops4.6
Python私教5 小时前
Hermes Agent 安全加固与生态扩展:2026-04-23 更新解析
人工智能
饼干哥哥5 小时前
Kimi K2.6 干成了Claude Design国产版,一句话生成电影级的动态品牌网站
人工智能
不爱吃炸鸡柳5 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
肖有米XTKF86465 小时前
带货者精品优选模式系统的平台解析
人工智能·信息可视化·团队开发·csdn开发云
天天进步20155 小时前
打破沙盒限制:OpenWork 如何通过权限模型实现安全的系统级调用?
人工智能·安全