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

CF1401B Ternary Sequence

CF1401B Ternary Sequence


题目描述

给定两个序列 \(a_1, a_2, \dots, a_n\)\(b_1, b_2, \dots, b_n\),每个序列中的元素都是 \(0\), \(1\)\(2\)。序列 \(a\)\(0\), \(1\), \(2\) 的个数分别为 \(x_1\), \(y_1\), \(z_1\),序列 \(b\)\(0\), \(1\), \(2\) 的个数分别为 \(x_2\), \(y_2\), \(z_2\)

你可以任意重新排列序列 \(a\)\(b\) 的元素。之后,定义序列 \(c\) 如下:

\[c_i = \begin{cases} a_i b_i, & \text{if } a_i > b_i, \\ 0, & \text{if } a_i = b_i, \\ -a_i b_i, & \text{if } a_i < b_i. \end{cases} \]

你希望使 \(\sum_{i=1}^n c_i\)(即序列 \(c\) 所有元素之和)尽可能大。请问最大可能的和是多少?


输入格式

第一行包含一个整数 \(t\)(\(1 \le t \le 10^4\)),表示测试用例的数量。

每个测试用例包含两行。每个测试用例的第一行包含三个整数 \(x_1, y_1, z_1\)(\(0 \le x_1, y_1, z_1 \le 10^8\)),分别表示序列 \(a\)\(0\), \(1\), \(2\) 的个数。

每个测试用例的第二行也包含三个整数 \(x_2, y_2, z_2\)(\(0 \le x_2, y_2, z_2 \le 10^8\),且 \(x_1 + y_1 + z_1 = x_2 + y_2 + z_2 > 0\)),分别表示序列 \(b\)\(0\), \(1\), \(2\) 的个数。


输出格式

对于每个测试用例,输出一个整数,表示序列 \(c\) 的最大可能和。


思路

  1. 先把c的各种取值情况分析一下,如下表:
a b c
a > b 2 1 2 使之尽可能多
2 0 0
1 0 0
a = b 2 2 0
1 1 0
0 0 0
a < b 1 2 -2 使之尽可能少
0 1 0
0 2 0
  1. 思路:希望使 \(\sum_{i=1}^n c_i\)(即序列 \(c\) 所有元素之和)尽可能大。即:使(a,b)=(2,1)最多,使(a,b)=(1,2)最少
0 1 2
a x y z
b xx yy zz
  1. 如何实现:使(a,b)=(2,1)最多,使(a,b)=(1,2)最少?

(1)使(a,b)=(1,2)最少:先用x消耗zz

(2)如果没有x消耗完zz,就用z消耗zz

(3)最后的答案就是剩余的(2,1)-(1,2)的个数的两倍,即2 * (min(z, yy) - min(y, zz))


AC代码

#include <bits/stdc++.h>
using namespace std;signed main()
{ios::sync_with_stdio(false);cin.tie(0);int t;cin >> t;while (t--){int x, y, z, xx, yy, zz, a, b;cin >> x >> y >> z >> xx >> yy >> zz;a = min(x, zz);x -= a;zz -= a;b = min(z, zz);z -= b;zz -= b;cout << 2 * (min(z, yy) - min(y, zz)) << '\n';}
}
http://www.hskmm.com/?act=detail&tid=37736

相关文章:

  • [DOS] Borland Turbo Assembler learning 8086/real-mode assembly
  • 搭建x86汇编语言学习环境
  • 闭包
  • Python---学习
  • 离在线SDK配置
  • 傅立叶,程心和路明泽
  • SpringBoot自动配置
  • AI元人文构想与余溪诗学空间:一场从诗意本源向智能未来的远征
  • 状压DP
  • 搞定三大PLC通讯:倍福与西门子、欧姆龙与西门子数据互通实战
  • 实验p66
  • 牛客2025秋季算法编程训练联赛2-(基础组提升组)
  • 局域网共享一键通_v2.0.9.9
  • newDay15
  • 每日反思(2025_10_23)
  • 树链剖分/轻重链剖分
  • 如何降低信息化系统的构建成本? ——信息化系统省钱全攻略:从规划到运维的实用技巧
  • C#编程时winform程序登陆记住密码和自动登录功能,关于App.config的问题及解决方案
  • 2025.10.23总结
  • Day2超链接标签
  • Ai元人文构想:你喜欢黑箱与偏见
  • 企业微信 使用api批量处理群消息
  • first game (1)
  • 10月23日日记
  • Gin笔记一之项目建立与运行
  • 软件工程学习日志2025.10.23
  • 10月23号
  • 【题解】P14254 分割(divide)
  • 数论分块 - R
  • 第九届强网杯线上赛PWN_flag-market