답안 #1110026

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1110026 2024-11-08T13:42:29 Z Mher777 PIN (CEOI10_pin) C++17
0 / 100
51 ms 20144 KB
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <iomanip>
#include <array>
#include <string>
#include <algorithm>
#include <cmath>
#include <set>
#include <map>
#include <unordered_set>
#include <unordered_map>
#include <vector>
#include <stack>
#include <queue>
#include <deque>
#include <bitset>
#include <list>
#include <iterator>
#include <numeric>
#include <complex>
#include <utility>
#include <random>
#include <cassert>
#include <fstream>
using namespace std;
mt19937 rnd(time(nullptr));

/* -------------------- Typedefs -------------------- */

typedef int itn;
typedef long long ll;
typedef unsigned long long ull;
typedef double db;
typedef float fl;
typedef long double ld;

/* -------------------- Usings -------------------- */

using vi = vector<int>;
using vll = vector<ll>;
using mii = map<int, int>;
using mll = map<ll, ll>;
using pii = pair<int, int>;
using pll = pair<ll, ll>;

/* -------------------- Defines -------------------- */

#define ff first
#define ss second
#define pub push_back
#define pob pop_back
#define puf push_front
#define pof pop_front
#define mpr make_pair
#define yes cout<<"Yes\n"
#define no cout<<"No\n"
#define all(x) (x).begin(), (x).end()
#define USACO freopen("feast.in", "r", stdin); freopen("feast.out", "w", stdout);

/* -------------------- Constants -------------------- */

const int dx[8] = { -1, 0, 1, 0, -1, -1, 1, 1 };
const int dy[8] = { 0, -1, 0, 1, -1, 1, -1, 1 };
const int MAX = int(1e9 + 5);
const ll MAXL = ll(1e18) + 5ll;
const ll MOD = ll(1000000007);
const ll MOD2 = ll(998244353);

/* -------------------- Functions -------------------- */

void fastio() {
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
}

void precision(int x) {
    cout.setf(ios::fixed | ios::showpoint);
    cout.precision(x);
}

ll gcd(ll a, ll b) {
    if (a == 0 || b == 0) return(max(a, b));
    while (b) {
        a %= b;
        swap(a, b);
    }
    return a;
}

ll lcm(ll a, ll b) {
    return a / gcd(a, b) * b;
}

ll range_sum(ll a, ll b) {
    if (a > b) return 0ll;
    ll dif = a - 1, cnt = b - a + 1;
    ll ans = ((b - a + 1) * (b - a + 2)) / 2;
    ans += ((b - a + 1) * dif);
    return ans;
}

string dec_to_bin(ll a) {
    string s = "";
    for (ll i = a; i > 0; ) {
        ll k = i % 2;
        i /= 2;
        char c = k + 48;
        s += c;
    }
    if (a == 0) {
        s = "0";
    }
    reverse(all(s));
    return s;
}

ll bin_to_dec(string s) {
    ll num = 0;
    for (int i = 0; i < s.size(); i++) {
        num *= 2ll;
        num += (s[i] - '0');
    }
    return num;
}

ll factorial_by_mod(ll n, ll mod) {
    ll ans = 1;
    ll num;
    for (ll i = 1; i <= n; ++i) {
        num = i % mod;
        ans *= num;
        ans %= mod;
    }
    return ans;
}

bool isPrime(ll a) {
    if (a == 1) return false;
    for (ll i = 2; i * i <= a; i++) {
        if (a % i == 0) return false;
    }
    return true;
}

ll binpow(ll a, ll b) {
    if (!a) return 0;
    ll ans = 1;
    while (b) {
        if (b & 1) {
            ans *= a;
        }
        b >>= 1;
        a *= a;
    }
    return ans;
}

ll binpow_by_mod(ll a, ll b, ll mod) {
    if (!a) return 0;
    ll ans = 1;
    while (b) {
        if (b & 1) {
            ans *= a;
            ans %= mod;
        }
        b >>= 1;
        a *= a;
        a %= mod;
    }
    return ans;
}

/* -------------------- Solution -------------------- */

const int N = 500005, M = (1 << 4) + 5;
string a[N];
ll a_hash[N], ans[M], han[M];
ll p = 31;
int n, k, m = 4;

ll count(int mask) {
    ll p_pow = 1, num;
    char c;
    for (int i = 1; i <= n; ++i) {
        a_hash[i] = 0;
        p_pow = 1;
        for (int bit = 0; bit < m; ++bit) {
            if ((1 << bit) & mask) {
                continue;
            }
            c = a[i][bit];
            if (c >= 'a' && c <= 'z') {
                num = c - 'a';
                ++num;
            }
            else {
                num = c - '0';
                num += 27;
            }
            a_hash[i] += p_pow * num;
            a_hash[i] %= MOD;
            p_pow *= p;
            p_pow %= MOD;
        }
    }
    sort(a_hash + 1, a_hash + n + 1);
    ll ret = 0;
    ll cnt = 1;
    for (int i = 2; i <= n; ++i) {
        if (a_hash[i] == a_hash[i - 1]) {
            ++cnt;
            continue;
        }
        ret += (cnt * (cnt - 1ll)) / 2ll;
        cnt = 1;
    }
    ret += (cnt * (cnt - 1ll)) / 2;
    return ret;
}

void change(int mask) {
    for (int mask1 = 0; mask1 < (1 << m); ++mask1) {
        if (mask == mask1) continue;
        bool f = true;
        for (int bit = 0; bit < m; ++bit) {
            int bit1 = 0, bit2 = 0;
            if ((1 << bit) & mask) bit1 = 1;
            if ((1 << bit) & mask1) bit2 = 1;
            if (bit1 == 1 && bit2 == 0) {
                f = false;
                break;
            }
        }
        if (f) {
            han[mask1] += ans[mask];
        }
    }
}

void slv() {
    cin >> n >> k;
    for (int i = 1; i <= n; ++i) {
        cin >> a[i];
    }
    ll answ = 0;
    for (int mask = 0; mask < (1 << m); ++mask) {
        ans[mask] = count(mask) - han[mask];
        change(mask);
        int number_of_ones = 0;
        for (int bit = 0; bit < m; ++bit) {
            if ((1 << bit) & mask) {
                ++number_of_ones;
                continue;
            }
        }
        if (number_of_ones == k) {
            answ += ans[mask];
        }
    }
    cout << answ;
}

/*
3 2
0011
1100
0011
*/

void cs() {
    int tstc = 1;
    //cin >> tstc;
    while (tstc--) {
        slv();
    }
}

void precalc() {
    return;
}

int main() {
    fastio();
    precalc();
    //precision(0);
    cs();
    return 0;
}

Compilation message

pin.cpp: In function 'll range_sum(ll, ll)':
pin.cpp:97:21: warning: unused variable 'cnt' [-Wunused-variable]
   97 |     ll dif = a - 1, cnt = b - a + 1;
      |                     ^~~
pin.cpp: In function 'll bin_to_dec(std::string)':
pin.cpp:120:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  120 |     for (int i = 0; i < s.size(); i++) {
      |                     ~~^~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Incorrect 6 ms 17744 KB Output isn't correct
2 Incorrect 5 ms 17744 KB Output isn't correct
3 Incorrect 5 ms 17828 KB Output isn't correct
4 Incorrect 20 ms 18172 KB Output isn't correct
5 Incorrect 25 ms 20144 KB Output isn't correct
6 Incorrect 28 ms 19792 KB Output isn't correct
7 Incorrect 20 ms 18000 KB Output isn't correct
8 Incorrect 28 ms 20048 KB Output isn't correct
9 Incorrect 40 ms 20048 KB Output isn't correct
10 Incorrect 44 ms 19960 KB Output isn't correct
11 Incorrect 25 ms 20048 KB Output isn't correct
12 Incorrect 51 ms 19792 KB Output isn't correct
13 Incorrect 30 ms 19792 KB Output isn't correct
14 Incorrect 28 ms 20048 KB Output isn't correct
15 Incorrect 46 ms 20048 KB Output isn't correct
16 Incorrect 34 ms 20048 KB Output isn't correct
17 Incorrect 50 ms 20048 KB Output isn't correct
18 Incorrect 38 ms 19792 KB Output isn't correct
19 Incorrect 44 ms 19792 KB Output isn't correct
20 Incorrect 50 ms 20048 KB Output isn't correct