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

Codeforces Round #956 (Div. 2) and ByteRace 2024

A题:Array Divisibility

思路:

大水题

code:

inline void solve() {int n; cin >> n;for (int i = 1; i <= n; i ++ ) {cout << i << " \n"[i == n];}return;
}

B题:Corner Twist 

思路:

模拟

任意一个矩形的修改,都可以下放到最小的2x2的小矩形,因此,我们只需在要修改的地方用2x2的小矩形修改即可。

code:

inline void solve() {int n, m; cin >> n >> m;vector<vector<int>> a(n + 1, vector<int>(m + 1)), b(n + 1, vector<int>(m + 1));for (int i = 1; i <= n; i ++ ) {for (int j = 1; j <= m; j ++ ) {char c; cin >> c;a[i][j] = c - '0';}}for (int i = 1; i <= n; i ++ ) {for (int j = 1; j <= m; j ++ ) {char c; cin >> c;b[i][j] = c - '0';}}function<void(int&, int)> add = [&](int &x, int c) {x = (x + c) % 3;};for (int i = 1; i <= n - 1; i ++ ) {for (int j = 1; j <= m - 1; j ++ ) {if (a[i][j] == b[i][j]) continue;int d = (b[i][j] - a[i][j] + 3) % 3;add(a[i][j], d), add(a[i + 1][j + 1], d);add(a[i + 1][j], 3 - d), add(a[i][j + 1], 3 - d);}}if (a == b) cout << "YES\n";else cout << "NO\n";return;
}

C题:Have Your Cake and Eat It Too 

思路:

贪心+二分,只是情况变多了而已。

code:

inline void solve() {int n; cin >> n;vector<vector<ll>> a(3, vector<ll>(n + 1));for (int i = 0; i < 3; i ++ ) {for (int j = 1; j <= n; j ++ ) {cin >> a[i][j];a[i][j] += a[i][j - 1];}}ll nd = (a[0][n] + 2) / 3;int cur[3] = {0, 1, 2};bool ok = false;function<bool(vector<ll>, vector<ll>, vector<ll>)> check = [&](vector<ll> a, vector<ll> b, vector<ll> c) {int l[3], r[3];l[0] = 0, r[0] = n + 1;while (l[0] + 1 != r[0]) {int mid = l[0] + r[0] >> 1;if (a[mid] < nd) l[0] = mid;else r[0] = mid;}l[0] = 1;if (r[0] >= n - 1) return false;l[1] = r[0], r[1] = n + 1;while (l[1] + 1 != r[1]) {int mid = l[1] + r[1] >> 1;if (b[mid] - b[r[0]] < nd) l[1] = mid;else r[1] = mid;}l[1] = r[0] + 1;if (r[1] >= n) return false;l[2] = r[1], r[2] = n + 1;while (l[2] + 1 != r[2]) {int mid = l[2] + r[2] >> 1;if (c[mid] - c[r[1]] < nd) l[2] = mid;else r[2] = mid;}l[2] = r[1] + 1;if (r[2] == n + 1) return false;r[2] = n;ok = true;for (int i = 0; i < 3; i ++ ) {for (int j = 0; j < 3; j ++ ) {if (cur[j] == i) {cout << l[j] << ' ' << r[j] << ' ';}}}cout << endl;return true;};do {if (check(a[cur[0]], a[cur[1]], a[cur[2]])) break;}while (next_permutation(cur, cur + 3));if (!ok) cout << -1 << endl;return;
}

http://www.lryc.cn/news/395253.html

相关文章:

  • 域名、网页、HTTP概述
  • Redisson分布式锁、可重入锁
  • 适合宠物饮水机的光电传感器有哪些
  • 『Python学习笔记』Python运行设置PYTHONPATH环境变量!
  • 2024年06月CCF-GESP编程能力等级认证Python编程三级真题解析
  • 代码随想录算法训练营:20/60
  • Apache Seata应用侧启动过程剖析——RM TM如何与TC建立连接
  • Origin 的使用
  • MySQL相关知识点
  • 第4章 Vite模块化与插件系统(二)
  • 前端传到后端的data数组中有些属性值为空
  • 怎么批量下载网页里的图片和视频 如何批量下载一个网站的所有图片 如何批量下载网页视频文件 idm软件怎么下载
  • Python面试题:在 Python 中,如何处理文件操作?
  • 红日靶机1
  • Windows电脑PC使用adb有线跟无线安装apk包
  • 如何把harmonos项目修改为openharmony项目
  • 【QT】Qt智能指针QPointer、QSharedPointer、QWeakPointer、QScopedPointer
  • 设计模式探索:建造者模式
  • [Go] 字符串遍历数据类型问题
  • HJ41 称砝码
  • 如何使用Python脚本实现SSH登录
  • 2024年文化研究与数字媒体国际会议 (CRDM 2024)
  • 14-52 剑和诗人26 - RAG 和 VectorDB 简介
  • 如果MySQL出现 “Too many connections“ 错误,该如何解决?
  • 论文阅读:Rethinking Interpretability in the Era of Large Language Models
  • C++/Qt 信号槽机制详解
  • duplicate key value violates unique constraint
  • YOLOv10改进 | EIoU、SIoU、WIoU、DIoU、FocusIoU等二十余种损失函数
  • docker nginx mysql redis
  • Linux系统(CentOS)安装iptables防火墙