栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

869. 重新排序得到 2 的幂

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

869. 重新排序得到 2 的幂

链接:869. 重新排序得到 2 的幂

题解:

class Solution {
public:
    bool reorderedPowerOf2(int n) {
        std::string str = std::to_string(n);
        sort(str.begin(), str.end());
        int begin = 0;
        std::vector visited(str.size(), false);
        std::vector path;
        int sum = 0;
        return dfs(begin, str, path, visited, sum);
        
    }
    bool dfs(int begin, const std::string& str, std::vector& path, std::vector& visited, int sum) {
        if (begin >= str.size()) {
            return two(sum);
        }
        for (int i = 0; i < str.size(); ++i) {
            //cout << str[i] << endl;
            if (begin == 0 && str[i] == '0') {
                continue;
            }
            if (visited[i]) {
                continue;
            }
            if (i-1 >= 0 && !visited[i-1] && str[i] == str[i-1]) {
                continue;
            }
            
            visited[i] = true;
            path.push_back(str[i]);
            if (dfs(begin+1, str, path, visited, sum*10 + (str[i]-'0'))) {
                return true;
            }
            path.pop_back();
            visited[i] = false;
        }
        return false;
    }
private:
    bool two(int n) {
        if (n == 1) {
            return true;
        }
        return (n&(n-1)) == 0 ? true : false;
    }
};

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/384964.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号