Educational Codeforces Round 134 (Rated for Div. 2)
Educational Codeforces Round 134 (Rated for Div. 2)#
D. Maximum AND#
给定两个数组和,可以对进行任意排列,定义,定义,求最大的。
这种求按位操作之后的最值,基本上就是从高位往低位枚举即可。
显然,最高位特别好计算,我们只需要判断中的数量和中0的数量是否一致即可,如果一致则最高位可以为,但是如果最高位为,在求解次高位时就不能以这种方式去处理了,因为我们得考虑上一位的限制。
因此,我们可以维护一个mask
代表上一位的限制,那么显然有的情况。实际上,我们维护mask
就是用来限定每个能与哪些进行匹配,注意,对于来说,我们需要按位取反(考虑到异或操作)。
最后,我们可以用个map
类似的数据结构来进行维护,代码如下,时间复杂度为:
constexpr int B = 29;
void solve(){
int n;
std::cin >> n;;
vt<int> a(n), b(n);
R1V(a, n);
R1V(b, n);
auto check = [&](int bits){
map<int, int> hsh;
for (int x: a) ++ hsh[x & bits];
for (int x: b) -- hsh[~x & bits];
int ok = 1;
for (auto &e: hsh) ok &= e.second == 0;
return ok;
};
int ans = 0;
for (int i = B; ~i; -- i){
if (check(ans | (1 << i)))
ans |= 1 << i;
}
wpr(ans);
}
E. Prefix Function Queries#
给定一个字符串 ,以及个查询。每次查询给出一个字符串,输出的前缀函数在末尾个位置的值。
这题容易想到首先计算出前个的fail
数组,然后基于此再对于后面这个进行计算,但是在最坏的情况下可能需要跳转次,所以我们需要进行优化。
这里需要用到可持久化KMP,但是目前我连KMP都没有做专题,所以我暂时放弃对于这部分的理解,补上几个链接:
好了 目前的任务先是把《算法导论》中的字符串部分全部学习完,再来补这个。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)