Submission #829185

# Submission time Handle Problem Language Result Execution time Memory
829185 2023-08-18T06:09:15 Z GrindMachine Broken Device (JOI17_broken_device) C++17
43 / 100
41 ms 2824 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;

    // ll big_rand = 87358979875987495ll;
    // X ^= big_rand;

    int seed = 123456789;
    mt19937 rng(seed);
    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);
    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++;
            }
        }
    }

    return ans;
}
# Verdict Execution time Memory Grader output
1 Partially correct 36 ms 2556 KB Output is partially correct - L* = 20
2 Partially correct 36 ms 2572 KB Output is partially correct - L* = 17
3 Partially correct 37 ms 2580 KB Output is partially correct - L* = 18
4 Partially correct 36 ms 2576 KB Output is partially correct - L* = 19
5 Partially correct 41 ms 2516 KB Output is partially correct - L* = 17
6 Partially correct 37 ms 2604 KB Output is partially correct - L* = 19
7 Partially correct 37 ms 2520 KB Output is partially correct - L* = 18
8 Partially correct 36 ms 2516 KB Output is partially correct - L* = 19
9 Partially correct 35 ms 2420 KB Output is partially correct - L* = 16
10 Partially correct 39 ms 2612 KB Output is partially correct - L* = 19
11 Partially correct 35 ms 2600 KB Output is partially correct - L* = 20
12 Partially correct 35 ms 2680 KB Output is partially correct - L* = 18
13 Partially correct 36 ms 2576 KB Output is partially correct - L* = 19
14 Partially correct 37 ms 2612 KB Output is partially correct - L* = 19
15 Partially correct 35 ms 2592 KB Output is partially correct - L* = 18
16 Partially correct 36 ms 2552 KB Output is partially correct - L* = 19
17 Partially correct 36 ms 2588 KB Output is partially correct - L* = 20
18 Partially correct 35 ms 2480 KB Output is partially correct - L* = 18
19 Partially correct 40 ms 2492 KB Output is partially correct - L* = 20
20 Partially correct 41 ms 2532 KB Output is partially correct - L* = 18
21 Partially correct 35 ms 2568 KB Output is partially correct - L* = 20
22 Partially correct 35 ms 2476 KB Output is partially correct - L* = 20
23 Partially correct 36 ms 2568 KB Output is partially correct - L* = 17
24 Partially correct 36 ms 2504 KB Output is partially correct - L* = 19
25 Partially correct 35 ms 2652 KB Output is partially correct - L* = 17
26 Partially correct 36 ms 2540 KB Output is partially correct - L* = 20
27 Partially correct 39 ms 2824 KB Output is partially correct - L* = 20
28 Partially correct 38 ms 2552 KB Output is partially correct - L* = 18
29 Partially correct 34 ms 2456 KB Output is partially correct - L* = 16
30 Partially correct 37 ms 2484 KB Output is partially correct - L* = 18
31 Partially correct 36 ms 2588 KB Output is partially correct - L* = 20
32 Partially correct 35 ms 2448 KB Output is partially correct - L* = 17
33 Partially correct 36 ms 2520 KB Output is partially correct - L* = 18
34 Partially correct 35 ms 2460 KB Output is partially correct - L* = 20
35 Partially correct 38 ms 2572 KB Output is partially correct - L* = 20
36 Partially correct 35 ms 2588 KB Output is partially correct - L* = 17
37 Partially correct 35 ms 2476 KB Output is partially correct - L* = 16
38 Partially correct 35 ms 2464 KB Output is partially correct - L* = 18
39 Partially correct 38 ms 2652 KB Output is partially correct - L* = 19
40 Partially correct 40 ms 2520 KB Output is partially correct - L* = 18