Submission #829193

# Submission time Handle Problem Language Result Execution time Memory
829193 2023-08-18T06:14:36 Z GrindMachine Broken Device (JOI17_broken_device) C++17
45 / 100
50 ms 2700 KB
// Om Namah Shivaya

#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>

using namespace std;
using namespace __gnu_pbds;

template<typename T> using Tree = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>;
typedef long long int ll;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;

#define fastio ios_base::sync_with_stdio(false); cin.tie(NULL)
#define pb push_back
#define endl '\n'
#define sz(a) a.size()
#define setbits(x) __builtin_popcountll(x)
#define ff first
#define ss second
#define conts continue
#define ceil2(x, y) ((x + y - 1) / (y))
#define all(a) a.begin(), a.end()
#define rall(a) a.rbegin(), a.rend()
#define yes cout << "Yes" << endl
#define no cout << "No" << endl

#define rep(i, n) for(int i = 0; i < n; ++i)
#define rep1(i, n) for(int i = 1; i <= n; ++i)
#define rev(i, s, e) for(int i = s; i >= e; --i)
#define trav(i, a) for(auto &i : a)

template<typename T>
void amin(T &a, T b) {
    a = min(a, b);
}

template<typename T>
void amax(T &a, T b) {
    a = max(a, b);
}

#ifdef LOCAL
#include "debug.h"
#else
#define debug(x) 42
#endif

/*

refs:
https://ivaniscoding.wordpress.com/2018/08/25/communication-3-broken-device/

*/

const int MOD = 1e9 + 7;
const int N = 1e5 + 5;
const int inf1 = int(1e9) + 5;
const ll inf2 = ll(1e18) + 5;

#include "Annalib.h"

void Anna( int n, long long X, int k, int a[] ){
    vector<int> blocked(n);
    rep(i,k) blocked[a[i]] = 1;

    vector<int> p(n);
    rep(i,n) p[i] = i;

    int seed = 123456789;
    mt19937 rng(seed);
    
    auto random = [&](ll l, ll r){
        return uniform_int_distribution<ll>(l,r)(rng);
    };

    ll big_rand = random(0,(1ll<<60)-1);
    X ^= big_rand;

    shuffle(all(p),rng);

    int bit = 0;
    vector<int> val(n);
    int prev_bit = -1;

    for(int i = 0; i < n-1; i += 2){
        if(bit < 60){
            int b = 0;
            if(X & (1ll<<bit)) b = 1;
            if(!blocked[p[i]]){
                if(blocked[p[i+1]] and b){
                    conts;
                }
                else{
                    val[p[i]] = 1;
                    val[p[i+1]] = b;
                    prev_bit = b;
                    bit++;
                }
            }
            else{
                if(!blocked[p[i+1]]){
                    if(b == prev_bit){
                        val[p[i+1]] = 1;
                        bit++;
                    }
                }
            }
        }
    }

    rep(i,n){
        Set(i,val[i]);
    }
}
// Om Namah Shivaya

#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>

using namespace std;
using namespace __gnu_pbds;

template<typename T> using Tree = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>;
typedef long long int ll;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;

#define fastio ios_base::sync_with_stdio(false); cin.tie(NULL)
#define pb push_back
#define endl '\n'
#define sz(a) a.size()
#define setbits(x) __builtin_popcountll(x)
#define ff first
#define ss second
#define conts continue
#define ceil2(x, y) ((x + y - 1) / (y))
#define all(a) a.begin(), a.end()
#define rall(a) a.rbegin(), a.rend()
#define yes cout << "Yes" << endl
#define no cout << "No" << endl

#define rep(i, n) for(int i = 0; i < n; ++i)
#define rep1(i, n) for(int i = 1; i <= n; ++i)
#define rev(i, s, e) for(int i = s; i >= e; --i)
#define trav(i, a) for(auto &i : a)

template<typename T>
void amin(T &a, T b) {
    a = min(a, b);
}

template<typename T>
void amax(T &a, T b) {
    a = max(a, b);
}

#ifdef LOCAL
#include "debug.h"
#else
#define debug(x) 42
#endif

/*

refs:
https://ivaniscoding.wordpress.com/2018/08/25/communication-3-broken-device/

*/

const int MOD = 1e9 + 7;
const int N = 1e5 + 5;
const int inf1 = int(1e9) + 5;
const ll inf2 = ll(1e18) + 5;

#include "Brunolib.h"

long long Bruno( int n, int a[] ){
    vector<int> p(n);
    rep(i,n) p[i] = i;

    int seed = 123456789;
    mt19937 rng(seed);
    
    auto random = [&](ll l, ll r){
        return uniform_int_distribution<ll>(l,r)(rng);
    };

    ll big_rand = random(0,(1ll<<60)-1);

    shuffle(all(p),rng);

    int bit = 0;
    int prev_bit = -1;
    ll ans = 0;

    for(int i = 0; i < n-1; i += 2){
        if(bit < 60){
            if(a[p[i]]){
                ans |= (1ll<<bit)*a[p[i+1]];
                prev_bit = a[p[i+1]];
                bit++;
            }
            else if(a[p[i+1]]){
                ans |= (1ll<<bit)*prev_bit;
                bit++;
            }
        }
    }

    ans ^= big_rand;

    return ans;
}
# Verdict Execution time Memory Grader output
1 Partially correct 41 ms 2564 KB Output is partially correct - L* = 19
2 Partially correct 44 ms 2452 KB Output is partially correct - L* = 19
3 Partially correct 47 ms 2532 KB Output is partially correct - L* = 22
4 Partially correct 34 ms 2452 KB Output is partially correct - L* = 20
5 Partially correct 35 ms 2528 KB Output is partially correct - L* = 23
6 Partially correct 50 ms 2424 KB Output is partially correct - L* = 21
7 Partially correct 50 ms 2456 KB Output is partially correct - L* = 21
8 Partially correct 41 ms 2584 KB Output is partially correct - L* = 21
9 Partially correct 34 ms 2532 KB Output is partially correct - L* = 20
10 Partially correct 34 ms 2576 KB Output is partially correct - L* = 20
11 Partially correct 34 ms 2512 KB Output is partially correct - L* = 18
12 Partially correct 43 ms 2584 KB Output is partially correct - L* = 23
13 Partially correct 37 ms 2520 KB Output is partially correct - L* = 23
14 Partially correct 33 ms 2612 KB Output is partially correct - L* = 22
15 Partially correct 44 ms 2448 KB Output is partially correct - L* = 22
16 Partially correct 35 ms 2608 KB Output is partially correct - L* = 20
17 Partially correct 35 ms 2664 KB Output is partially correct - L* = 20
18 Partially correct 40 ms 2700 KB Output is partially correct - L* = 22
19 Partially correct 35 ms 2568 KB Output is partially correct - L* = 20
20 Partially correct 36 ms 2632 KB Output is partially correct - L* = 24
21 Partially correct 41 ms 2568 KB Output is partially correct - L* = 20
22 Partially correct 41 ms 2572 KB Output is partially correct - L* = 23
23 Partially correct 37 ms 2544 KB Output is partially correct - L* = 20
24 Partially correct 34 ms 2540 KB Output is partially correct - L* = 19
25 Partially correct 43 ms 2584 KB Output is partially correct - L* = 22
26 Partially correct 34 ms 2548 KB Output is partially correct - L* = 20
27 Partially correct 34 ms 2660 KB Output is partially correct - L* = 19
28 Partially correct 36 ms 2556 KB Output is partially correct - L* = 21
29 Partially correct 35 ms 2560 KB Output is partially correct - L* = 22
30 Partially correct 41 ms 2568 KB Output is partially correct - L* = 22
31 Partially correct 35 ms 2476 KB Output is partially correct - L* = 21
32 Partially correct 35 ms 2520 KB Output is partially correct - L* = 21
33 Partially correct 34 ms 2548 KB Output is partially correct - L* = 21
34 Partially correct 37 ms 2544 KB Output is partially correct - L* = 22
35 Partially correct 34 ms 2608 KB Output is partially correct - L* = 17
36 Partially correct 36 ms 2504 KB Output is partially correct - L* = 20
37 Partially correct 35 ms 2464 KB Output is partially correct - L* = 21
38 Partially correct 35 ms 2532 KB Output is partially correct - L* = 19
39 Partially correct 35 ms 2648 KB Output is partially correct - L* = 21
40 Partially correct 36 ms 2520 KB Output is partially correct - L* = 20