2457. 美丽整数的最小增量

题目

本题我之前也是和题解一样的想法,增加数还让它和变小只有进位操作可以。

关键在写法上,我是转为字符串去计算每次增加多少,比较麻烦。这种做法还是比较好,记录下。

cpp 复制代码
class Solution {
public:
    long long makeIntegerBeautiful(long long n, int target) {
       long long cur=n;
       long long i=10;
        while(true){
            int cursum=func(cur);
            if(cursum<=target)
                return cur-n;           //第一次    第二次
            cur/=i;                     //123->12   130->1
            cur++;                      //12->13    1->2
            cur*=i;                     //13->130   2->200
            i*=10;                      //注意,不可以将i变为10,因为随着次数增加,第一次需要10.第二次需要100
        }
        return 0;
    }
    int func(long long cur){
        int sum=0;
        while(cur>0){
            sum+=cur%10;
            cur/=10;
        }
        return sum;

    }
};
相关推荐
逝雪Yuki37 分钟前
牛客——接头密匙
c++·字典树·前缀树·数据结构与算法
三小尛1 小时前
C++拷贝构造函数
开发语言·c++
码农葫芦侠2 小时前
C++继承中虚函数调用时机问题及解决方案
c++·qt
一只余弦函数2 小时前
《C++》STL--list容器详解
开发语言·c++·list
爱学习的小邓同学2 小时前
C++ --- stack和queue的使用以及简单实现
c++
霜羽68922 小时前
【C++篇】模版进阶
开发语言·c++
超闻逸事3 小时前
题解:CF2129C Interactive RBS
c++·算法·codeforces
一方热衷.4 小时前
YOLOv8/YOLOv11 C++ OpenCV DNN推理
c++·opencv·yolo
玖剹4 小时前
Linux文件系统:从内核到缓冲区的奥秘
linux·c语言·c++·笔记·ubuntu