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);
相关推荐
学历真的很重要42 分钟前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
普通网友42 分钟前
微服务注册中心与负载均衡实战精要,微软 2025 年 8 月更新:对固态硬盘与电脑功能有哪些潜在的影响。
人工智能·ai智能体·技术问答
苍何1 小时前
一人手搓!AI 漫剧从0到1详细教程
人工智能
苍何1 小时前
Gemini 3 刚刷屏,蚂蚁灵光又整活:一句话生成「闪游戏」
人工智能
苍何1 小时前
越来越对 AI 做的 PPT 敬佩了!(附7大用法)
人工智能
苍何1 小时前
超全Nano Banana Pro 提示词案例库来啦,小白也能轻松上手
人工智能
Savior`L2 小时前
二分算法及常见用法
数据结构·c++·算法
阿杰学AI2 小时前
AI核心知识39——大语言模型之World Model(简洁且通俗易懂版)
人工智能·ai·语言模型·aigc·世界模型·world model·sara
智慧地球(AI·Earth)2 小时前
Vibe Coding:你被取代了吗?
人工智能
mmz12072 小时前
前缀和问题(c++)
c++·算法·图论