当前位置: 首页 > news >正文

Aoao Round 2 比赛总结

分数: \(100 + 25 + 20 + 0 = 145\)

好一个神秘 seq 赛。

T1

不难发现,一个符合要求的序列需要是连续的,且其中比 \(b\) 大的数和比 \(b\) 小的数数量相等。

因此,我们可以以 \(b\) 为起点,分别向两侧扫描,把比 \(b\) 小的数记作 \(-1\),比 \(b\) 大的数记作 \(1\),并分别计算其前缀和。当左侧的某个前缀和和右侧的某个前缀和成相反数时,此时左右比 \(b\) 大和比 \(b\) 小的数的数量就会恰好相等,那么就找到了一个符合要求的序列。

在代码实现中,为了方便,当在 \(b\) 右侧进行扫描时,我们可以把比 \(b\) 大的记作 \(-1\),比它小的记作 \(1\)(与上面的描述相反),然后把左右两侧前缀和分别放入两个桶中。然后左右两个桶相同位置的数的乘积之和即为答案。

别忘了开 long long,不然就会挂掉 55 分。

跳过代码

#include <bits/stdc++.h>
typedef long long ll;
const int N = 2e5+10;
int a[N], n, posB, b;
ll val[N], lBuc[2 * N + 10], rBuc[2 * N + 10];
ll ans = 0;int main() {freopen("empty.in", "r", stdin);freopen("empty.out", "w", stdout);std::ios::sync_with_stdio(false); std::cin.tie(0);std::cin >> n >> b;for (int i = 1; i <= n; i++) {std::cin >> a[i];if (a[i] == b) posB = i;}for (int i = posB - 1; i >= 1; i--) {if (a[i] < b) {val[i] = val[i+1] - 1;} else val[i] = val[i+1] + 1;}for (int i = posB + 1; i <= n; i++) {if (a[i] < b) val[i]  = val[i-1] + 1;else val[i] = val[i-1]-1;}const int ADD = 2e5+10;for (int i = 1; i <= posB; i++) {lBuc[val[i] + ADD]++;}for (int i = posB; i <= n; i++) {rBuc[val[i] + ADD]++;}for (int i = 0; i <= 2 * N; i++) {ans += lBuc[i] * rBuc[i];}std::cout << ans << '\n';return 0;
}

T2

当我看到题解时,虎躯一震——这道题竟然是图论?!

是的,这是一道典型的图论建模题目。我们可以把每个整数当成图上的一个节点,然后定义:相邻的两个整数的二进制只有一位不同 (有点像格雷码)。

可以注意到 \(\max(\operatorname{nailong}(x, y)) + \min(\operatorname{nailong}(\sim x, y)) = m\)。 考虑 BFS,对序列中的每个数取反,并以其为原点开始。每次搜相邻的整数,如果这个数还没有被搜索过,就记录其步数,并将其加入队列。然后,答案就是 \(m\) 与序列中每个数步数的最小值的差。

#include <bits/stdc++.h>
typedef long long ll;
const int N = 1.1e6+10;
int a[N], n, m, step[N], vis[N];int main() {freopen("purple.in", "r", stdin);freopen("purple.out", "w", stdout);std::ios::sync_with_stdio(false); std::cin.tie(0);std::cin >> n >> m;for (int i = 1; i <= n; i++) {std::cin >> a[i];}std::queue<int> q;for (int i = 1; i <= n; i++) {q.push(((1 << m) - 1) ^ a[i]);vis[(((1 << m) - 1) ^ a[i])] = true;}while (!q.empty()) {int u = q.front();q.pop();for (int i = 0; i < m; i++) {int v = u ^ (1 << i);if (!vis[v]) {vis[v] = true;q.push(v);step[v] = step[u] + 1;}}}for (int i = 1; i <= n; i++) {std::cout << m - step[a[i]] << ' ';}return 0;
}
http://icebutterfly214.com/news/34274/

相关文章:

  • locust基础
  • 荆门定制西林瓶灌装机费用解析,比标准款贵多少?
  • 基于Ubuntu2504部署OpenStack E版
  • 常见的无状态服务与典型有状态服务
  • 【IEEE出版 | 连续4年稳定EI检索】第五届新能源与电力工程国际学术会议(ICNEPE 2025)
  • 5分钟极简代码:轻松学会XXTEA加密解密
  • 【SPIE出版 | 快速见刊检索】第二届电子信息工程与智能通信国际研讨会(EIC 2025)
  • 中国数据集成平台TOP10综合评估报告(2025)
  • 告别重复“点点点”!基于Dify工作流,打造能思考、会决策的自主测试智能体
  • python异步协程
  • 软件工程团队作业2
  • EMS4100N芯祥科技USB3.1高速双向模拟开关芯片资料,可pin对pin替代ASW3410
  • 2025年空化液体电辅供热机组定制厂家权威推荐榜单:电锅炉/工业电锅炉/水分子物化供热机组源头厂家精选
  • 一份用pyhon生成word/wps文档的代码
  • LangChain PromptTemplate 全解析:从模板化提示到智能链构 - 教程
  • systemd-timedated.service Dbus参考
  • 2025年11月酵母抽提物品牌榜:五强横评与鲜味稳定性对比
  • 【日记】解决了一个人际冲突,但耳机怕是永远找不回来了(1344 字)
  • 2025年评价高的短视频运营最新TOP厂家排名
  • 2025年专业的负氧离子床垫厂家最新TOP排行榜
  • 2025年评价高的PPH储罐优质厂家推荐榜单
  • 2025年优质的学生宿舍铁床厂家推荐及采购指南
  • 2025年知名的全屋定制榻榻米行业内口碑厂家排行榜
  • 2025年知名的中性铝溶胶最新TOP品牌厂家排行
  • 2025年质量好的签字中性笔最新TOP品牌厂家排行
  • 2025年口碑好的液冷储能柜厂家选购指南与推荐
  • 2025年评价高的ABS防撞碳晶板厂家推荐及选购指南
  • 2025年评价高的电力支架厂家最新推荐排行榜
  • 2025年11月deepseek排名优化推荐:AI生态适配能力为核心的服务商选择宝典
  • 2025年11月豆包搜索排名优化推荐:数据驱动的全链路效果提升解决方案