LeetCode 2048. 下一个更大的数值平衡数

一、题目

1、题目描述

如果整数 x 满足:对于每个数位 d ,这个数位 恰好 在 x 中出现 d 次。那么整数 x 就是一个 数值平衡数 。

给你一个整数 n ,请你返回 严格大于 n 的 最小数值平衡数。

0 <= n <= 1e6

2、接口描述

c++class 复制代码
public:
    int nextBeautifulNumber(int n) {
    }
};

3、原题链接

2048. 下一个更大的数值平衡数

二、解题报告

1、思路分析

对于一个数我们我们可以在O(C)的时间复杂度内判断出其是否为数值平衡数,C为其位数,即我们按照数位遍历数字即可判断一个数值平衡数。

而n的范围最大不超过1e6,所以我们只要从1判断到1224445即可

2、复杂度

时间复杂度: O ( n ) 空间复杂度: O ( 1 ) 时间复杂度:O(n)\\ 空间复杂度:O(1) 时间复杂度:O(n)空间复杂度:O(1)

3、代码详解

c++ 复制代码
class Solution {
public:
    int nextBeautifulNumber(int n) {
        if(!n) return 1;
        function<bool(int)> dfs = [](int x) -> bool
        {
            int hash[8]{0};
            while(x)
            {
                if(x % 10 >= 7) return false;
                hash[x % 10]++; x /= 10;
            }
            int i = 0;
            for(i = 0 ; i < 8 && (hash[i] == i || !hash[i]) ; i++); 
            return i == 8;
        };
        int i;
        for(i = n < 22 ? 22 : n + 1 ; i < 1224445 ; i++)
        {
            if(dfs(i)) return i;
        }
        return i;
    }
};
相关推荐
mjhcsp6 分钟前
C++ 递推与递归:两种算法思想的深度解析与实战
开发语言·c++·算法
_OP_CHEN11 分钟前
算法基础篇:(三)基础算法之枚举:暴力美学的艺术,从穷举到高效优化
c++·算法·枚举·算法竞赛·acm竞赛·二进制枚举·普通枚举
m0_7482480218 分钟前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
java·开发语言·c++·算法
天选之女wow20 分钟前
【代码随想录算法训练营——Day61】图论——97.小明逛公园、127.骑士的攻击
算法·图论
aloha_78926 分钟前
测试开发工程师面经准备(sxf)
java·python·leetcode·压力测试
im_AMBER1 小时前
Leetcode 47
数据结构·c++·笔记·学习·算法·leetcode
kyle~1 小时前
算法数学---差分数组(Difference Array)
java·开发语言·算法
橘颂TA1 小时前
机器人+工业领域=?
算法·机器人
小O的算法实验室2 小时前
2025年TRE SCI1区TOP,随机环境下无人机应急医疗接送与配送的先进混合方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小白程序员成长日记3 小时前
2025.11.06 力扣每日一题
算法·leetcode