同样只过了A
题
英文菜鸡,看样例才知道是不能连续使用同一weapon
然后还**地分
UPD
:
B
题和做的思路差亿点点,可惜自己多虑跑去干E
由题意得出在
E
题:
首先切入点是考虑每一位上的情况:对于第
而事实上如果遍历每一位的较强要求下的结果,就能覆盖到原题较弱要求下的解
然后上快读都被报TLE
,最后map
换成cc_hash_table
才3166ms苟过测试点9
UPD
:
C
如果所有节点异或和为而对于分割成三个部分以上的情况
A
:
```cpp
const LL N = 1e3 + 86;
LL t, n, h, a[N], dp[N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin >> t;
f(sb, 1, t)
{
cin >> n >> h;
f(i, 1, n) cin >> a[i - 1];
sort(a, a + n);
LL max1, max2;
max1 = a[n - 1];
max2 = a[n - 2];
LL res = h / (max1 + max2) * 2;
h %= (max1 + max2);
while (h > 0)
{
if (res & 1)
h -= max2;
else
h -= max1;
res += 1;
}
cout << res << ‘\n’;
}
return 0;
}
<code>B</code>
```cpp
onst LL N = 1e5 + 86;
LL t, n, x, a[N], b[N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin >> t;
f(sb, 1, t)
{
cin >> n >> x;
bool vis = 1;
f(i, 1, n)
{
cin >> a[i - 1];
b[i - 1] = a[i - 1];
}
sort(a, a + n);
for (int i = n - x; i <= x - 1; i++)
{
if (a[i] != b[i])
vis = 0;
}
if (vis)
cout << "YES\n";
else
cout << "NO\n";
}
return 0;
}
E
#include<ext/pb_ds/assoc_container.hpp>
#include<ext/pb_ds/hash_policy.hpp>
onst LL N = 1e6 + 86;
LL n, a[N], ans, pref[N];
int main()
{
//IN;
//OUT;
n = io.xint();
f(i, 1, n) a[i] = io.xint();
for (int k = 20; k >= 0; k--)
{
__gnu_pbds::cc_hash_table<LL, std::vector<LL> > vis[2];
vis[0][0].pb(0);
f(i, 1, n) pref[i] = (a[i] >> k) ^ pref[i - 1], vis[i & 1][pref[i]].pb(i);
LL l = 0;
for (LL r = 1; r <= n; r++)
{
if ((a[r] >> k) & 1)
{
std::vector<LL> &v = vis[r & 1][pref[r]];
std::vector<LL>::iterator it = std::lower_bound(v.begin(), v.end(), l);
if(it != v.end())
ans = ans < r - *it ? r - *it : ans;
}
else l=r;
}
}
io.wll(ans);
return 0;
}
C
:
const int N = 1e5 + 86;
int t, n, k, a[N], xo[N], x, c, b, flag;
vector<int> v[N];
int dfs(int now, int fa)
{
xo[now] = a[now];
for (auto it : v[now])
{
if (it == fa)
continue;
xo[now] ^= dfs(it, now);
}
return xo[now];
}
void fi(int now, int fa)
{
for (auto it : v[now])
{
if (it == fa)
continue;
fi(it, now);
if (xo[it] == x && flag == 0)
{
flag = 1;
v[now].erase(find(v[now].begin(), v[now].end(), it));
return;
}
}
}
int main()
{
//IN;
//OUT;
ios::sync_with_stdio(false);
cin.tie(0);
t = io.xint();
f(sb, 1, t)
{
x = 0;
n = io.xint();
k = io.xint();
f(i, 1, n)
{
a[i] = io.xint();
x ^= a[i];
v[i].clear();
}
f(i, 1, n - 1)
{
c = io.xint();
b = io.xint();
v[c].pb(b);
v[b].pb(c);
}
if (x == 0)
{
io.wstring("YES\n");
continue;
}
else if (k == 2)
{
io.wstring("NO\n");
continue;
}
flag = 0;
dfs(1, 1);
fi(1, 1);
//io.wll(flag);
if (flag == 1)
{
flag = 0;
dfs(1, 1);
fi(1, 1);
if (flag == 1)
io.wstring("YES\n");
else
io.wstring("NO\n");
continue;
}
io.wstring("NO\n");
}
return 0;
}