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

一、题目

1、题目描述

如果整数 x 满足:对于每个数位 d ,这个数位 恰好 在 x 中出现 d 次。那么整数 x 就是一个 数值平衡数 。
给你一个整数 n ,请你返回 严格大于 n 的 最小数值平衡数。
0 <= n <= 1e6

2、接口描述

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、代码详解

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;
    }
};

相关推荐

  1. LeetCode 2048. 一个数值平衡

    2023-12-11 01:30:02       41 阅读
  2. leetcode做题笔记2048. 一个数值平衡

    2023-12-11 01:30:02       33 阅读
  3. LeetCode 2454. 一个元素 IV

    2023-12-11 01:30:02       43 阅读
  4. Leetcode 496. 一个元素 I

    2023-12-11 01:30:02       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-11 01:30:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-11 01:30:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-11 01:30:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-11 01:30:02       18 阅读

热门阅读

  1. Linux结束程序运行的命令

    2023-12-11 01:30:02       35 阅读
  2. dubbo

    dubbo

    2023-12-11 01:30:02      35 阅读
  3. C++特殊类设计

    2023-12-11 01:30:02       35 阅读
  4. 5.3 函数-递归与求阶乘

    2023-12-11 01:30:02       28 阅读
  5. 人工智能原理复习

    2023-12-11 01:30:02       35 阅读
  6. 第9节:Vue3 指令

    2023-12-11 01:30:02       35 阅读