#include <algorithm>
#include <array>
#include <string>

class Solution {
    using freq_t = std::array<std::size_t, 26>;

    freq_t freqs(const std::string& word)
    {
        freq_t f { 0 };

        for (auto c : word) {
            f[c - 'a']++;
        }

        return f;
    }

    int mask(const freq_t& f)
    {
        int m = 0;

        for (auto c : f) {
            m = (m << 1) | (c > 0);
        }

        return m;
    }

public:
    bool closeStrings(std::string word1, std::string word2)
    {
        auto f1 = freqs(word1);
        auto m1 = mask(f1);
        std::sort(f1.begin(), f1.end());

        auto f2 = freqs(word2);
        auto m2 = mask(f2);
        std::sort(f2.begin(), f2.end());

        return m1 == m2 && f1 == f2;
    }
};