This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define pb push_back
#define vii vector<int>
#define task "ABC"
#define pll pair<ll, ll>
#define pii pair< pll, ll >
#define fi first
#define se second
using namespace std;
using ll = int;
using ull = unsigned long long;
const int N = 3e5+5;
const ll mod = 1e9+7;
const ll base1 = 1313;
const ll base2 = 3113;
ll m, n, k, t, T, ans, tong, cur;
string s;
ll pw(ll k, ll n)
{
ll total = 1;
for(; n; n >>= 1)
{
if(n & 1)total = total * k % mod;
k = k * k % mod;
}
return total;
}
vector<ll> paint(int n)
{
//cin >> n;
vector<ll> kq, a, b;
ll lf = 1, rt = 15, mid;
while(lf <= rt)
{
mid = (lf + rt) / 2;
tong = (1<<mid) + mid-1;
if(tong < n)lf = mid + 1;
else rt = mid - 1;
}
k = lf;
a.resize(n+2);
b.resize((1<<k)+5);
tong = 0;
for(int i = 1; i <= min(k, n); i++)
{
kq.pb(1);
tong = tong * 2 + 1;
}
if(k <= n)a[k] = tong;
b[tong] = 1;
for(int i = k+1; i <= n; i ++)
{
t = a[i-1] * 2;
t &= tong;
if(b[t] == 0)kq.pb(0);
else
{
t += 1;
kq.pb(1);
}
a[i] = t;
b[t] = 1;
}
kq.pb(k);
return kq;
}
int find_location(int n, vector<int> c)
{
vector<int> a, b;
k = c.size();
tong = 0;
ans = 0;
for(int i = 0; i < k; i ++)
{
if(c[i] == -1)
{
return n-i;
}
if(c[i])ans = ans * 2 + 1;
else ans = ans * 2;
tong = tong * 2 + 1;
}
a.resize(n+2);
b.resize((1<<k)+5);
a[k] = tong;
if(tong == ans)
{
return 1;
}
for(int i = k+1; i <= n; i ++)
{
t = a[i-1] * 2;
t &= tong;
if(b[t])++t;
a[i] = t;
b[t] = 1;
if(a[i] == ans)
{
return i-k+1;
}
}
}
Compilation message (stderr)
squares.cpp: In function 'int find_location(int, std::vector<int>)':
squares.cpp:71:17: warning: control reaches end of non-void function [-Wreturn-type]
71 | vector<int> a, b;
| ^
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |