3099.力扣每日一题7/3 Java(击败100%)

  • 博客主页:音符犹如代码
  • 系列专栏:算法练习
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍

目录

思路

解题方法

时间复杂度

空间复杂度

Code


思路

首先要解决如何获取一个整数各个数位上的数字之和。这可以通过不断对数字进行取余和整除操作来逐位获取数字,并累加求和。

然后,判断这个整数是否能被求得的数字之和整除。如果能整除,就返回数字之和;不能整除,就返回 -1 。

整体来说,思路就是先分解数字求其各位数字之和,再进行整除判断得出结果。

解题方法

首先,通过一个循环计算输入数字 x 各个数位上的数字之和,并将其存储在变量 sum 中。然后,判断 x 是否能被 sum 整除,如果能整除则返回 sum,否则返回 -1

时间复杂度

计算数字之和的循环执行的次数取决于数字 x 的位数,设数字 xn 位,那么时间复杂度为 O(n)

空间复杂度

只使用了固定的几个整型变量来存储中间结果和最终结果,空间复杂度为 O(1)

Code

java 复制代码
class Solution {
    public int sumOfTheDigitsOfHarshadNumber(int x) {
        int sum = 0;
        int num = x;

        while (num > 0) {
            sum += num % 10;
            num /= 10;
        }

        if (x % sum == 0) {
            return sum;
        } else {
            return -1;
        }
    }
}

"过去都是幻觉。而未来还有可期"------《了不起的盖茨比》弗朗西斯·斯科特·菲茨杰拉德

相关推荐
我真的是大笨蛋22 分钟前
K8S-Pod(下)
java·笔记·云原生·容器·kubernetes
碳水加碳水1 小时前
Java代码审计实战:XML外部实体注入(XXE)深度解析
java·安全·web安全·代码审计
纪元A梦1 小时前
贪心算法应用:化工反应器调度问题详解
算法·贪心算法
深圳市快瞳科技有限公司1 小时前
小场景大市场:猫狗识别算法在宠物智能设备中的应用
算法·计算机视觉·宠物
liulilittle2 小时前
OPENPPP2 —— IP标准校验和算法深度剖析:从原理到SSE2优化实现
网络·c++·网络协议·tcp/ip·算法·ip·通信
努力也学不会java2 小时前
【设计模式】 原型模式
java·设计模式·原型模式
方渐鸿2 小时前
【2024】k8s集群 图文详细 部署安装使用(两万字)
java·运维·容器·kubernetes·k8s·运维开发·持续部署
学亮编程手记2 小时前
K8S v1.33 版本主要新特性介绍
java·容器·kubernetes
Haven-3 小时前
Java-面试八股文-JVM篇
java·jvm·面试
我真的是大笨蛋4 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构