当前位置: 首页 > article >正文

力扣 66.加一 (Java实现)

题目分析

        给定一个数组,可以组成一个数字,将数字加一后,返回新数组

思路分析

        首先跟着题目思路走,将数组按位*10可以得到数字,再加一,加一后按位%10,可以得到新的数组。但是此处数字会过大,导致数字溢出,切换为long型后,数字过大也会让乘除的操作精度丢失。

        换个思路,跳过数组与数字转换。这个题目的重点就在于最后一位,如果最后一位小于9,则最后一位+1,然后直接输出数组。如果是9,则考虑进位,如果全是9,则进位后首位为1,其余为0;

代码


class Solution {
    public int[] plusOne(int[] digits) {
        int n=digits.length-1;//题目给定数组的末位
        for(int i=n;i>=0;i--){//从末尾到首位遍历
            if(digits[i]<9){//如果这一位不为9
                digits[i]++;该位+1
                return digits;//直接输出
            }
            digits[i]=0;//如果为9,就先把这一位变成0,同时继续循环,直到遇到不为9的值
        }
        int[] re=new int[n+2];//此处为全是9的情况,需要新数组多一位
        re[0]=1;//首位1,其余0
        return re;//输出新数组
    }
}

        今天走人户,所以在网吧做进不去cf,今天就做一道力扣吧

        感谢您能够看到这里,一起见证小何同学的算法学习,如果您有不同的见解,希望能得到您的指点和点悟;如果您是和我一样的同学,也希望这篇文章能对您有所帮助。


http://www.kler.cn/a/548951.html

相关文章:

  • 17二叉搜索树的lca、插入、删除
  • 动手实现一个PDF阅读器
  • 知识图谱Neo4j网页版的快速使用(详细教程:安装+基础使用)
  • stm32mp15x 之 M4 使用 canfd
  • 麒麟系统离线安装SVN
  • 大语言模型常用微调与基于SFT微调DeepSeek R1指南
  • 区块链安全:使用安全的数字孪生框架构建智能、健康的城市
  • 开业盛典活动策划方案拆解
  • 如何解决DeepSeek服务器繁忙的问题?
  • 【从0做项目】Java搜索引擎(3)
  • Linux中退出vi编辑器的命令
  • Unity-Mirror网络框架-从入门到精通之PlayerTest示例
  • vLLM专题(三)-快速开始
  • 【Leetcode 952】按公因数计算最大组件大小
  • 3.buuctf [BSidesCF 2019]Kookie
  • 最新智能优化算法: 贪婪个体优化算法(Greedy Man Optimization Algorithm,GMOA)求解23个经典函数测试集,MATLAB代码
  • Vue3+NestJS实现后台权限管理系统上线啦!(附源码及教程)
  • 【RocketMQ 存储】CommitLogDispatcherBuildConsumeQueue 构建 ConsumeQueue 索引
  • 蓝桥杯 Java B 组之栈的应用(括号匹配、表达式求值)
  • 【第13章:自监督学习与少样本学习—13.3 自监督学习与少样本学习在图像识别、语言理解等领域的应用探索】