2023牛客暑期多校训练营2(D/E/F/H/I/K)

目录

D.The Game of Eating

E.Square

F.Link with Chess Game

H.0 and 1 in BIT

I.Link with Gomoku

K.Box


D.The Game of Eating

思路:倒着贪心。因为正着贪会导致一种局面:我选了当前喜爱值最大的菜,但是就算我不选这个菜,后面的人也可能选这一道菜,我依然能吃上这道菜,那么我为什么不选其它的菜而两者兼得呢?所以我们考虑倒着贪心。贪心到第i个人时,根据喜爱值从大到小遍历一遍菜,如果这个菜被后面的人选过了,那就不选了,直到有一个菜是没被选过的。

bool cmp(PII a,PII b) {return a.first>b.first;
}
void solve() {map<int,int>mp;int n,m,k;cin>>n>>m>>k;for(int i=1; i<=n; i++)v[i].clear();for(int i=1; i<=n; i++) {for(int j=1; j<=m; j++) {int x;cin>>x;v[i].push_back({x,j});}sort(v[i].begin(),v[i].end(),cmp);}for(int i=k; i>=1; i--) {int now=i%n,j=0;if(!now)now=n;while(mp[v[now][j].second])j++;mp[v[now][j].second]=true;}for(auto x:mp) {cout<<x.first<<" ";}cout<<endl;
}

 

E.Square

思路:题目的公式可以表示为,求Y使得:

Y^2-(Y^2)%(10^K) = X*(10^K)

 可见只需枚举K的大小然后判断即可。 

代码:

string cmp;
bool pd(int y) {string now=to_string(y*y);while(now.size()<cmp.size())now+='0';//防止runtime errorfor(int i=0; i<cmp.size(); i++) {if(cmp[i]!=now[i])return false;//有一位不相同就不合法答案}return true;
}
void solve() {int x;cin>>x;cmp=to_string(x);for(int k=0; k<=9; k++) {//枚举k的大小int now=pow(10,k)*x;int y=sqrt(now);if(pd(y)) {//判断这个y是否合法cout<<y<<endl;return;}if(pd(y+1)) {//因为y*y会减掉一部分余数,所以要判一下y+1cout<<y+1<<endl;return;}}cout<<-1<<endl;
}

F.Link with Chess Game

思路:若只有一个棋子,当棋子有距离边界为奇数长度的局面为先手必胜态,因为两个人必须在这个奇数区间里一直走,而先手可以一直选到所有位置选完。该情况可推广至三个棋子,三个棋子的距离端点距离可以抽象为所有棋子距离端点的距离之和,棋子可以在端点之和为奇数的区间内反复横跳,来保持自己的最终的奇偶性,从而导致先手必胜,反之先手必败。

代码:

void solve() {int n,a,b,c;cin>>n>>a>>b>>c;int sum1=(a-1)+(b-1)+(c-1);int sum2=(n-a)+(n-b)+(n-c);if(sum1%2||sum2%2)cout<<"Alice"<<endl;else cout<<"Bob\n";
}

H.0 and 1 in BIT

思路:操作A相当于将x变成反码,也就是在取模意义下,操作A会令x=-x-1,而操作B会x=x+1,所以我们先开两个前缀和数组,一个记录前缀A的个数,一个记录前缀的贡献,然后在每次操作中,若l~r的区间内的A的个数为奇数,则原本的贡献要乘上-1,如此模拟即可。

代码:

int sum1[maxn],sum2[maxn];
//sum1记录前缀A的个数,sum2记录前缀的贡献
void solve() {int n,q,l,r,L,R,ans=0;string s,x;cin>>n>>q>>s;for(int i=1; i<=n; i++) {sum1[i]=sum1[i-1]+(s[i-1]=='A');if(s[i-1]=='A')sum2[i]=-sum2[i-1]-1;else sum2[i]=sum2[i-1]+1;}while(q--) {int sum=0;cin>>l>>r>>x;L=min((ans^l)%n+1,(ans^r)%n+1),R=max((ans^l)%n+1,(ans^r)%n+1);int now1=(sum1[R]-sum1[L-1])%2,now2;for(int i=0; i<x.size(); i++) {sum=sum*2+(x[i]-'0');}//将x转换为10进制,方便与贡献进行运算if(now1) {//若区间A的个数为奇数,则贡献*-1now2=sum2[R]+sum2[L-1];sum=-sum;} else now2=sum2[R]-sum2[L-1];int mod=(1<<(int)x.size());ans=(now2+sum+mod)%mod;for(int i=(int)x.size()-1; i>=0; i--) {cout<<((ans>>i)&1);}cout<<endl;}
}

I.Link with Gomoku

思路:在前面的n-n%2行中,摆放方式和题目样例一样:

xxxxoxxxxoxxxxo......

ooooxooooxoooox......

最后一行若为奇数行,则这样摆放即可:

xoxoxoxoxo......

代码: 

void solve() {int n,m;cin>>n>>m;for(int i=1; i<=n-n%2; i++) {int cnt=0;for(int j=1; j<=m; j++) {if(cnt%5==4) {//前4个放相同的 if(i%2)cout<<"o";//行与行之间连续4个xo交替放 else cout<<"x";} else {//最后一个放不同的 if(i%2)cout<<"x";else cout<<"o";}cnt++;}cout<<endl;}if(n%2) {//若最后一行为奇数行则xoxox......交替放 for(int i=1; i<=m; i++) {if(i%2)cout<<"x";else cout<<"o";}cout<<endl;}
}

K.Box

思路:我们设:

dp[i][0]表示第i位移动到i-1位的情况

dp[i][1]表示第i位不移动的情况

dp[i][2]表示第i位移动到i+1位的情况

具体实现见代码注释。

代码:

void solve() {int n;cin>>n;for(int i=1; i<=n; i++)cin>>a[i];for(int i=1; i<=n; i++)cin>>b[i];for(int i=1; i<=n; i++) {if(b[i]) {//只有1有主动权,0是被迫的QAQdp[i][0]=dp[i-1][0]+a[i-1];//当前1左移只能由上一个1左移转移过来dp[i][1]=max(dp[i-1][0],dp[i-1][1])+a[i];//当前位置不动,上一个位置1不动或者左移都可以dp[i][2]=max({dp[i-1][0],dp[i-1][1],dp[i-1][2]})+a[i+1];//当前位置右移,上一个位置1不动、左移、右移都可以} else {dp[i][0]=max({dp[i-1][0],dp[i-1][1]});// 当前位左移,可以由上一个位置左移,或者上一个位置1还没动的过转移过来dp[i][1]=dp[i-1][2];//这个0可以被上个右移的1挤到左边}}cout<<max(dp[n][0],dp[n][1])<<endl;//最终答案在左移和不动的情况下取max(因为最后一个位置无法右移)
}

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

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

相关文章

PostgreSQL实战-数据库迁移部署

PostgreSQL实战-数据库迁移部署 介绍 根据项目需求&#xff0c;我们需要将现有的PostgreSQL数据库重新部署到新的服务器上。由于项目本身就是基于PostgreSQL数据库构建的&#xff0c;因此数据库迁移将变得十分便捷。接下来&#xff0c;我将简要介绍我们的迁移步骤。 迁移步骤…

halcon线扫描相机平面交点检测--

目录 代码示例代码示例的逐句解释 以下是halcon中的代码示例 * This example shows the inspection of planar intersections of * 3D objects. The intersections are derived by intersecting the * reconstructed 3D object models with suitable planes, using the * o…

2.1 色彩空间

色彩发送器 色彩认知&#xff1a;光源是出生点&#xff0c;光源发射出光线&#xff0c;光线通过直射反射折射等路径最终进入人眼。但是人眼接收到光线后&#xff0c;人眼的细胞产生了一系列化学反应。由此把产生的新号传入大脑&#xff0c;最终大脑对颜色产生了认知感知。 光的…

如何把爱好变成事业?

如何把爱好变成事业&#xff1f; 目录 引言爱好与事业的关系如何把爱好变成事业 研究市场需求建立专业技能制定计划与目标 追求爱好的「变现」的利与弊 利&#xff1a;工作的乐趣与激情弊&#xff1a;压力与挑战 如何平衡爱好与事业 分清爱好与事业的界限建立时间管理和优先级…

数据结构-时间空间复杂度

目录 前言 1.什么是数据结构 2.什么是算法 3.数据结构和算法的重要性 1.算法的时间复杂度和空间复杂度 1.1算法效率 1.1.1如何衡量一个算法的好坏 1.1.2算法的复杂度 1.2时间复杂度 1.2.1时间复杂度的概念 1.2.2大O的渐进表示法 2.编程练习 2.1.1 排序遍历 2.1.2 2.1.3 单身狗解…

第一百一十六天学习记录:C++提高:STL-string(黑马教学视频)

string基本概念 string是C风格的字符串&#xff0c;而string本质上是一个类 string和char区别 1、char是一个指针 2、string是一个类&#xff0c;类内部封装了char*&#xff0c;管理这个字符串&#xff0c;是一个char型的容器。 特点&#xff1a; string类内部封装了很多成员方…

[JAVAee]wait方法与sleep方法的区别

①最明显的一个区别是,wait方法需要搭配synchronized关键字进行使用.而sleep方法的使用不需要 ②wait是一个Object类的方法,sleep是Thread类的一个静态方法 方法说明 public static void sleep(long millis) throws interruptedException 使当前正在执行的线程以指定的毫秒数…

PostMan+Jmeter工具介绍及安装

目录 一、PostMan介绍​编辑 二、下载安装 三、Postman与Jmeter的区别 一、开发语言区别&#xff1a; 二、使用范围区别&#xff1a; 三、使用区别&#xff1a; 四、Jmeter安装 附一个详细的Jmeter按照新手使用教程&#xff0c;感谢作者&#xff0c;亲测有效。 五、Jme…

windows无盘启动技术开发之使用本地镜像文件启动电脑

by fanxiushu 2023-07-26 转载或引用请注明原始作者。 其实使用本地镜像文件启动电脑&#xff0c;这个windows操作系统本身就是自带的功能。 win7以上的系统&#xff0c;制作 vhd或vhdx格式的镜像文件&#xff0c; 然后在镜像文件中安装windows操作系统&#xff0c;然后放到真实…

【数据结构】树状数组和线段树

树状数组和线段树 下文为自己的题解总结&#xff0c;参考其他题解写成&#xff0c;取其精华&#xff0c;做以笔记&#xff0c;如有描述不清楚或者错误麻烦指正&#xff0c;不胜感激&#xff0c;不喜勿喷&#xff01; 树状数组 需求&#xff1a; 能够快速计算区间和保证在修改…

fastadmin采坑之接口分页处理

其实不算fastadmin的代码而是thinkphp自带的分页代码 paginate函数就是自带的分页函数&#xff0c;开始我以为这个只能用于渲染模板不能用于接口&#xff0c;后面看到源代码发现请求参数带page就可以 /*** ApiTitle (获取协会会员)* ApiSummary (获取协会会员)* ApiMethod …

Langchain 的 Routerchain

Langchain 的 Routerchain 1. destination_chains2. LLMRouterChain3. EmbeddingRouterChain 本笔记本演示了如何使用 RouterChain 范例创建一个链&#xff0c;该链动态选择用于给定输入的下一个链。 路由器链由两个组件组成&#xff1a; RouterChain 本身&#xff08;负责选…

React 基础篇(二)

&#x1f4bb; React 基础篇&#xff08;二&#xff09;&#x1f3e0;专栏&#xff1a;React &#x1f440;个人主页&#xff1a;繁星学编程&#x1f341; &#x1f9d1;个人简介&#xff1a;一个不断提高自我的平凡人&#x1f680; &#x1f50a;分享方向&#xff1a;目前主攻…

微服务SpringCloud教程——微服务是什么

微服务&#xff08;MicroServices&#xff09;最初是由 Martin Fowler 于 2014 年发表的论文《MicroServices》中提出的名词&#xff0c;它一经提出就成为了技术圈的热门话题。 微服务&#xff0c;我们可以从字面上去理解&#xff0c;即“微小的服务”&#xff0c;下面我们从“…

excel 生成sql技巧

"update 表名 set 字段名"&A2&" where 字段名"&B2&";"

【C语言进阶】程序环境和预处理

&#x1f525;博客主页&#xff1a;小王又困了 &#x1f4da;系列专栏&#xff1a;C语言 &#x1f31f;人之为学&#xff0c;不日近则日退 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 目录 一、程序的翻译环境和执行环境 二、详解编译和链接 2.1翻译环境 2.2编译的过…

现代控制理论

B站学习视频https://space.bilibili.com/230105574/channel/seriesdetail?sid1569601 一.引入状态-空间表达 &#xff08;本质上是使用一组向量的线性组合来表示整个系统任意物理量&#xff0c;也就是一个特征分解的过程&#xff09; 现代控制理论的基础是 状态-空间表达方…

Emacs之实现跨程序选中自动复制功能(一百一十八)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

贪心算法重点内容

贪心算法重点内容 4.1部分背包 按照单位重量的价值排序 4.2最小生成树 两种算法 4.3单源最短路径 4.4哈夫曼树

linux下lazarus开发ide里 BGRAControls控件库comboBox示例

下载开发工具 ftp://ftp.freepascal.org/pub/lazarus/releases/Lazarus%20Linux%20amd64%20DEB/Lazarus%202.2.6/https://sourceforge.net/projects/lazarus/files/Lazarus%20Linux%20amd64%20DEB/Lazarus%202.2.6/ sourceforge下载可能比较慢&#xff0c;选择 下载有问题&…