【CF】Day6——Codeforces Round 942 (Div. 2) BC + Codeforces Round 941 (Div. 2) C

B. Coin Games

题目:

思路:

虽然标签是博弈论,但我感觉更像一个找规律的思维题

由于题目告诉我们每次只能选U,那我们不妨来考虑选U会造成什么情况(以下都为选中间U)

①.UUU = -3*U

此时选了U会导致两侧的U变为D,同时自身消失,此时相当于消去了三个U

②.UUD/DUU = -U

此时选了U会导致左右两侧相反,同时自身消失,此时左右两侧转变后对还是UD/DU形式,故只消耗了一个U

③.DUD = +U

此时选了U会导致增加两个U,但是自身会消失,所以总的来说是增加了一个U

综上所述,无论怎么选U,每次都是奇数次变化,也就是说只要总U数是奇数,那么先手必赢,否者后者获胜

代码:

#include <iostream>
#include <algorithm>
#include<cstring>
#include<cctype>
#include<string>
#include <set>
#include <vector>
#include <cmath>
#include <queue>
#include <unordered_set>
#include <map>
#include <unordered_map>
#include <stack>
#include <memory>
using namespace std;
#define ll long long
#define yes cout << "YES\n"
#define no cout << "NO\n"void solve()
{int n;cin >> n;string s;cin >> s;int cnt = 0;for (int i = 0; i < s.length(); i++){cnt += (s[i] == 'U');}if (cnt & 1)yes;else no;
}int main()
{cin.tie(0)->sync_with_stdio(false);int t = 1;cin >> t;while (t--){solve();}return 0;
}

C. Everything Nim

(这题是后面的C题,但是也是博弈论,一起说了)

题目:

思路:

这题才有博弈,首先我们可以考虑特殊情况,只要我们数组中有1,那么就只能选1,这是一个关键点,那么在数组中没有1前,我们只能选1

注意:这题主要看的是不同元素个数,因为每次选取都对所有堆都进行了操作,所以我们可以用set来储存不同元素个数就行了,以下的数组都是set

那么假设现在数组中没有1了,假设最小的数是k,那么k肯定是大于等于2的,因为数组中没1了,那我们先不管谁是先手,那么对于任意一个人,如果我们想要赢的话,那最后一步肯定是自己走,也就是说最后一堆肯定是被那个人一次性拿完,那么现在就有两种情况

①.如果只剩一堆

显然可以直接赢

②.如果剩了两堆or以上

那么对于先手,要想最后一步是自己,那么我可以这样,每次选k-1个,这样后手只能选一个,那么就能保证每一堆都是自己先手

所以现在就很简单了,首先将数组的1清空,然后看谁先手就行了,肯定是此时的先手赢

特殊的,如果一个数组是这样的 1 2 3 4 5 ,对于这样的连续数组,显然每次是选1,那么此时的结果就是取决与数组长度的奇偶性了

代码:

#include <iostream>
#include <algorithm>
#include<cstring>
#include<cctype>
#include<string>
#include <set>
#include <vector>
#include <cmath>
#include <queue>
#include <unordered_set>
#include <map>
#include <unordered_map>
#include <stack>
#include <memory>
using namespace std;
#define ll long long
#define yes cout << "YES\n"
#define no cout << "NO\n"void solve()
{int n;cin >> n;set<int> a;for (int i = 0; i < n; i++){int x; cin >> x;a.insert(x);}int sizeofa = a.size();int mex = 1;for (auto x : a){if (x == mex){mex++;}}mex--;if (mex >= sizeofa)//mex把数组中元素都遍历了一遍,且1~mex-1(sizeofa)都有了,故A是一个连续数组{//此时就取决于a中不同元素的数量cout << (sizeofa % 2 == 1 ? "Alice" : "Bob") << endl;}else{//此时看选完所有1后谁先手cout << (mex % 2 == 0 ? "Alice" : "Bob") << endl;}
}int main()
{cin.tie(0)->sync_with_stdio(false);int t = 1;cin >> t;while (t--){solve();}return 0;
}

C. Permutation Counting

(非常好题目,使我的思维旋转)

题目:

思路:

先说做法:二分答案 + 思维(构造)

对于题目要求,既然我们要增加答案,那我们肯定要构造越多的1~n排列越好,而排列的数量取决于所有数字的最小值,但是这个最小值不好求,因为k的范围高达1e12,因此我们可以使用二分答案的方法,我们可以假设最小值为mid,然后对于每次二分我们就检测所有数与mid相差多少,如果这个数小于mid,那么肯定要分配,否则就不分配,所以我们可以简单求出是否符合

注意二分的check,然后最后我们跳出二分后我们再看看是l更合适还是r更合适

那么我们有了最小数字后,那我们来看看如何构造才能使得答案最大呢?

显然肯定是像如下这样构造

1 2 3 ... n 1 2 3 ... n ...

这样的话每次1都可以与前面的2 3 4 ... n 又构成一个新的排列

这样得出来的答案就是 1 +(min - 1)* n 了

那我们在考虑多的数能不能利用呢?

比如1 2 3 3 2,如果按上诉排,那么就是 1 2 3 2 3这样了,显然这肯定不是最优的,那么我们换一种方式,如 3 2 1 3 2,我们发现这样的答案肯定是最优的,因为多出来的数都利用到了

我们可以形式化的表示构造方法:(多 多 多 ... 多 少 少 少 ...) * n,表示有n个这样的结构(循环)

这样的话多出来的就可以继续放少的后面再构造一个新的排列(有点贪心的想法)

同时既然这道题不需要我们输出排列方式,那真的省了很大功夫

所以最后的答案就是 1 + (min - 1)* n + add

其中add为每个元素是否多,如果多就加1,表示为(\sum (a[i] > min))

代码:

#include <iostream>
#include <algorithm>
#include<cstring>
#include<cctype>
#include<string>
#include <set>
#include <vector>
#include <cmath>
#include <queue>
#include <unordered_set>
#include <map>
#include <unordered_map>
#include <stack>
#include <memory>
using namespace std;
#define ll long long
#define yes cout << "YES\n"
#define no cout << "NO\n"ll n, k;
bool check(const vector<ll>& a,ll mid)
{ll need = 0;for (int i = 0; i < n; i++){if (a[i] < mid)need += mid - a[i];}return need <= k;
}void solve()
{cin >> n >> k;vector<ll> a(n);for (int i = 0; i < n; i++){cin >> a[i];}ll l = 0,r = 2e12;while (l+1 < r){ll mid = l + r >> 1;if (check(a,mid)){l = mid;}else{r = mid;}}ll mn = check(a,r) ? r : l;ll add = 0;for (int i = 0; i < n; i++){if (a[i] < mn){ll need = mn - a[i];a[i] += need;k -= need;}}for (int i = 0; i < n; i++){if (a[i] == mn && k){k--;a[i]++;}if (a[i] > mn){add++;}}ll ans = n * (mn - 1) + 1 + add;cout << ans << endl;
}int main()
{cin.tie(0)->sync_with_stdio(false);int t = 1;cin >> t;while (t--){solve();}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/33376.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视频推拉流EasyDSS案例分析:互联网直播/点播技术与平台创新应用

随着互联网技术的快速发展&#xff0c;直播/点播平台已成为信息传播和娱乐的重要载体。特别是在电视购物领域&#xff0c;互联网直播/点播平台与技术的应用&#xff0c;不仅为用户带来了全新的购物体验&#xff0c;也为商家提供了更广阔的营销渠道。传统媒体再一次切实感受到了…

鸿蒙初级考试备忘

Module类型 Module按照使用场景可以分为两种类型&#xff1a; Ability类型的Module&#xff1a; 用于实现应用的功能和特性。每一个Ability类型的Module编译后&#xff0c;会生成一个以.hap为后缀的文件&#xff0c;我们称其为HAP&#xff08;Harmony Ability Package&#x…

【QT】文件系统相关 -- QFile

一、Qt 文件概述 &#x1f525; 文件操作是应用程序必不可少的部分。Qt 作为⼀个通用开发库&#xff0c;提供了跨平台的文件操作能力。Qt 提供了很多关于⽂件的类&#xff0c;通过这些类能够对文件系统进行操作&#xff0c;如文件读写、文件信息获取、文件制或重命名等 二、输…

EasyCVR安防视频汇聚平台助力工业园区构建“感、存、知、用”一体化智能监管体系

在现代工业园区的安全管理和高效运营中&#xff0c;视频监控系统扮演着不可或缺的角色。然而&#xff0c;随着园区规模的扩大和业务的复杂化&#xff0c;传统的视频监控系统面临着诸多挑战&#xff0c;如设备众多难以统一管理、数据存储分散、智能分析能力不足、信息利用率低下…

鸿蒙路由 HMrouter 配置及使用一

1、学习链接 HMRouter地址 https://gitee.com/hadss/hmrouter/blob/dev/HMRouterLibrary/README.md 2、工程配置 下载安装 ohpm install hadss/hmrouter 添加编译插件配置 在工程目录下的build-profile.json5中&#xff0c;配置useNormalizedOHMUrl属性为true (我这项目创…

Tcp网络通信的基本流程梳理

先来一张经典的流程图 接下介绍一下大概流程&#xff0c;各个函数的参数大家自己去了解加深一下印象 服务端流程 1.创建套接字&#xff1a;使用 socket 函数创建一个套接字&#xff0c;这个套接字后续会被用于监听客户端的连接请求。 需要注意的是&#xff0c;服务端一般有俩…

Nexus File类型Blob Stores迁移至Minio操作指南(下)

#作者&#xff1a;闫乾苓 文章目录 迁移步骤停止nexus3服务备份nexus原始数据修改Blob Stores中元数据文件中类型为s3将Blob Stores中的二进制构件文件数据复制s3&#xff08;minio&#xff09;存储修改OrientDB中相关Blob Stores的属性修复OrientDB的文件权限开启nexus3服务迁…

mapbox基础,使用线类型geojson加载symbol符号图层,用于标注文字

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️symbol符号图层样式1.4 ☘️line线图层…

《C语言中“输入魔法师”:scanf函数的奥秘与技巧》

&#x1f680;个人主页&#xff1a;fasdfdaslsfadasdadf &#x1f4d6;收入专栏&#xff1a;C语言 &#x1f30d;文章目入 一、引言二、scanf函数的基本语法三、格式说明符的种类及用法&#xff08;一&#xff09;整数输入&#xff08;二&#xff09;浮点数输入&#xff08;三&…

Quickwit+Jaeger+Prometheus+Grafana搭建Java日志管理平台

介绍 生产服务应用可观测性在当下比较流行的方案&#xff0c;其中出现了大量高性能、开箱即用、易上手的的开源产品&#xff0c;大大丰富了在可观测性领域产品的多样性&#xff0c;本文讲述基于OTLP协议推送Java项目遥测数据&#xff08;日志、指标、链路&#xff09;到后端存储…

Unity Timeline 扩展

这里认为大家已经会timeline的基本使用了&#xff0c;只介绍怎么自定义扩展。 第一步.自定义Track 首先要自定义一条轨道。剪辑是要在轨道里跑的&#xff0c;系统自带的轨道我们加不了自定义剪辑&#xff0c;得新建自己用的。这个很简单。 [TrackClipType(typeof(TransformTw…

文生图技术的演进、挑战与未来:一场重构人类创造力的革命

摘要 文生图&#xff08;Text-to-Image Generation&#xff09;技术作为生成式人工智能&#xff08;Generative AI&#xff09;的核心分支&#xff0c;正在以颠覆性力量重塑内容生产范式。本文系统梳理文生图技术从早期实验到多模态大模型的演进路径&#xff0c;分析其在设计、…

如何手动使用下载并且运行 QwQ-32B-GGUF

首先使用安装 pip install ModelScope 使用 ModelScope 下载对应的模型 modelScope download --model Qwen/QwQ-32B-GGUF qwq-32b-q4_k_m.gguf 第二步开始下载 ollama git clone https://githubfast.com/ggerganov/llama.cpp # githubfast.com 可以加速下载 切换到目录&am…

SPring 学习积累1 关于下载相关jdk maven 版本

3.15.1 注意下载的版本 有些是不适配的&#xff0c;官网有提示&#xff1b; 3.15.2 注意配置环境变量时需要注意admistartor 中的java路径和系统变量是否一致&#xff0c;一行要一致&#xff0c;不然后续安装maven之后&#xff0c;使用命令 mvn -version时会显示以下错误&…

Excel(函数篇):Vlookup函数 详细用法

目录 Vlookup函数基础用法精确查找易错问题员工信息查询表 进阶用法近似匹配&#xff08;模糊查找&#xff09;结合通配符查找反向查找 高级技巧多条件查找动态列查询 错误处理屏蔽错误值处理数字/文本格式问题注意事项常见错误解决方案 拓展用法跨表与跨工作簿查找查找返回多列…

对最近的刷题做一个小总结(关于动态规划和贪心)

文章目录 1. 小总结2. 两道算法题2.1 数组中两个字符串的最小距离2.2 孩子们的游戏 1. 小总结 最近刷了很多算法题&#xff0c;真正了解到的算法应是dfs&#xff0c;多元dfs&#xff0c;以及动态规划和贪心。 dfs和多元dfs目前并没有真正深入研究过&#xff0c;不过熟悉套路之…

jmeter分布式原理及实例

一、执行原理 二、相关注意事项 关闭防火墙所有上网控制机、代理机、服务器都在同一个网络上所有机器的jmeter和java版本必须一致关闭RMI.SSL开关 三、配置和执行 配置&#xff1a; 修改bin/jmeter.properties文件&#xff1a; 代理机&#xff1a; 修改服务端口&#xff1…

C++ STL 详解 ——vector 的深度解析与实践指南

一、vector 的核心概念与底层机制 1.1 动态数组的本质 连续内存存储&#xff1a;与普通数组相同&#xff0c;vector 使用连续的内存空间&#xff0c;支持 O (1) 时间复杂度的随机访问。动态扩容特性&#xff1a;通过push_back等操作自动调整容量&#xff0c;无需手动管理内存…

【SpringBoot】——在做一些项目中所学到的新的技术栈和一些小技巧(主要为MQ,详细请看目录和文章)

&#x1f3bc;个人主页&#xff1a;【Y小夜】 &#x1f60e;作者简介&#xff1a;一位双非学校的大三学生&#xff0c;编程爱好者&#xff0c; 专注于基础和实战分享&#xff0c;欢迎私信咨询&#xff01; &#x1f386;入门专栏&#xff1a;&#x1f387;【MySQL&#xff0…

0经验cursor开发一款跨端app

设备&#xff1a;mac电脑cursor 1.输入诉求 我要实现一个跨端的地址应用&#xff0c;使其可以在ios、安卓、小程序和网页端都可以使用。这是一个demo的项目&#xff0c;功能不必要太过复杂&#xff0c;下面需要你和我多次沟通完成这个任务。你先根据我的内容输入&#xff0c…