leetcode每日一题系列-重新排序得到2的幂-「暴力搜索」

165 阅读1分钟

leetcode-869-重新得到2的幂

[博客链接]

菜🐔的学习之路

掘金首页

[题目链接]

题目链接

[github地址]

github地址

[题目描述]

给定正整数 N ,我们按任何顺序(包括原始顺序)将数字重新排序,注意其前导数字不能为零。

如果我们可以通过上述方式得到 2 的幂,返回 true;否则,返回 false。

 

示例 1:

输入:1
输出:true

示例 2:

输入:10
输出:false

示例 3:

输入:16
输出:true

示例 4:

输入:24
输出:false

示例 5:

输入:46
输出:true

提示:

1 <= N <= 10910^9

思路一:暴力搜索

  • 做字符串匹配,把范围内所有2的幂全部全部存入set即可

static class Solution {
    static Set<String> target = new HashSet<>();

    static {
        int init = 1;
        for (int i = 0; i <= 31; i++) {
            String temp = String.valueOf(init);
            StringBuilder sb = getString(temp);
            target.add(sb.toString());
            init *= 2;
        }
    }

    public static boolean reorderedPowerOf2(int n) {

        return target.contains(getString(String.valueOf(n)).toString());

    }

    private static StringBuilder getString(String temp) {
        PriorityQueue<Character> priorityQueue = new PriorityQueue<>();
        for (Character c : temp.toCharArray()) {
            priorityQueue.add(c);
        }
        StringBuilder sb = new StringBuilder();
        while (!priorityQueue.isEmpty()) {
            sb.append(priorityQueue.poll());
        }
        return sb;
    }
}
  • 时间复杂度O(m*n)
  • 空间复杂度O(1)