2023牛客暑期多校训练营2

D.The Game of Eating

思路:考虑贪心。每个人都会选择一道对于自身价值最大的菜,但考虑到其他人会帮自己提供一定的贡献,即样例二,第一个只需要点第三道菜,第二个人点第四道菜,自动帮第一个人补全了第四道价值最大的菜,所以当前人的选择可能要考虑到后续人员的影响,既然如此,我们考虑最后一个人,即最后一个进行点菜时,没有人对其选择造成影响,然后依次往前推,每个人取当前的最大价值即可。

#include <bits/stdc++.h>using namespace std;
const int N = 1e6 + 10;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<int, 3> p3;
int mod = 51123987;
const int maxv = 4e6 + 5;int st[2005];
int a[2005][2005];
void solve()
{memset(st,0,sizeof st);int n,m,k;cin>>n>>m>>k;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++) cin>>a[i][j];}int res=k%n;if(res==0) res=n;vector<int> ans;for(int i=res;i>=1;i--){int val=0;int c=0;for(int j=1;j<=m;j++){if(st[j]) continue;if(a[i][j]>val){val=a[i][j];c=j;}}st[c]=1;ans.push_back(c);if(i==1) i=n+1;k--;if(k==0) break;}sort(ans.begin(),ans.end());for(auto x: ans) cout<<x<<" ";cout<<endl;}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t = 1;cin >> t;while (t--){solve();}//cout<<endl;system("pause");return 0;
}

E.The Game of Eating

思路:考虑去枚举每个k,因为k最多只能到18,数据范围很小,然后按照题意去模拟即可。

#include<bits/stdc++.h>using namespace std;
const int N=1e5+5;
typedef long long ll;
typedef pair<ll,ll> pll;
int mod=998244353;
const int maxv=4e6+5;void solve()
{	ll n;cin>>n;ll x=10;for(int i=0;;i++){if(i==0) x=1;else x*=10;if(x*n>1e18) break;ll t=sqrtl(x*n);if(t*t/x==n) {cout<<t<<endl;return ;}if((t+1)*(t+1)/x==n){cout<<t+1<<endl;return; }}cout<<-1<<endl;
}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t=1;cin>>t;while(t--){solve();}system("pause");return 0;
}

F.Link with Chess Game

思路:官方题解给定的是二分图博弈,以后有空在去了解吧。

当n为偶数时,先手必胜,当为奇数时,和r,g,b的状态相同,当r,g,b为偶数的时候先手必胜。

#include <bits/stdc++.h>using namespace std;
const int N = 1e6 + 10;
typedef long long ll;
typedef pair<int, int> pll;
typedef array<int, 3> p3;
int mod = 1e9 + 7;
const int maxv = 4e6 + 5;void solve()
{int n,r,g,b;cin>>n>>r>>g>>b;if(n%2==0){cout<<"Alice"<<endl;return ;}else{if((r+g+b)%2==0){cout<<"Alice"<<endl;return ;}}cout<<"Bob"<<endl;}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t = 1;cin >> t;while (t--){solve();}system("pause");return 0;
}

G.Link with Centrally Symmetric Strings

题意:题目给定关于回文对称的新定义,然后问是否可以将给定字符串拆解成若干个回文字符串。

思路:关于回文字符串,我们可以用马拉车算法处理出每个位置上的回文半径,然后设置一个变量f 在遍历整个字符串时去记录最长的不合法的长度,若当前位置的回文半径大于不合法长度,那么直接跳到i+f处。最后变量值若为0则表示为合法字符串。

接下来来证明为什么这么做是对的:

1 若给定字符串s不嫩被拆解成若干个回文对称字符串,即存在某一些位置不是回文对称的,那么从该位置开始,变量f值会一直大于后续的所有的回文半径。因为只要出现回文半径大于f的情况,f就会被置为0,重新开始。

2 若给定字符串能够被拆解成若干个回文对称字符串,那么每当匹配到回文对称中心时,此时的位置距离前一个回文字符串的结尾距离即为p[i],而此时的回文半径长度肯定是大于f的,所以会一直匹配下去。

#include <bits/stdc++.h>using namespace std;
const int N = 1e6 + 10;
typedef long long ll;
typedef pair<int, int> pll;
typedef array<int, 3> p3;
int mod = 1e9 + 7;
const int maxv = 4e6 + 5;int z[300];
int p[N*2];void solve()
{string s;cin>>s;string a;a='#';for(int i=0;i<s.size();i++){a.push_back(s[i]);a.push_back('#');}a=" "+a;int n=a.size();for(int i=1;i<n;i++){if(z[a[i]]==a[i]) p[i]=1;else p[i]=0;}int r=0,m=0;for(int i=1;i<n;i++){if(i<r) p[i]=min(p[m*2-i],r-i+1);while(z[a[p[i]+i]]==a[i-p[i]]&&p[i]+i<n) p[i]++;if(i+p[i]-1>r){r=i+p[i]-1;m=i;}}int f=0;for(int i=1;i<n;i++){//cout<<p[i]<<" ";if(p[i]>f){i+=f;f=0;}else f++;}if(!f){cout<<"Yes"<<"\n";}else cout<<"No"<<"\n";}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t = 1;cin >> t;z['b']='q';z['q']='b';z['d']='p';z['p']='d';z['n']='u';z['u']='n';z['o']='o';z['s']='s';z['x']='x';z['z']='z';z['#']='#';while (t--){solve();}system("pause");return 0;
}

思考:为什么是将当前位置加上变量f,而不是直接让i加上回文半径p:考虑下述情况:

 当我们将字符串的黄色部分遍历完后(保证此种情况l1的右界小于l2),此时f=0,当我们遍历到对称中心l1时,我们若直接让i加上对应的回文半径p[l1]时,会直接变为l2附近,那么后续会出现还有一半的蓝色部分不为回文字符串。若是加上对应的f,因为f的值肯定是小于对应回文半径的,所以在其回文半径内,即使半径进行减小,也为回文字符串。所以此时让i加上对应的f到蓝色字符串的开头即可。然后蓝色字符串匹配到l2出自然会结束匹配。

I.Link with Gomoku

题意:给定一个n*m的棋盘下五子棋,让构造出一个棋局为和棋。

思路:按照样例模拟即可。即放四个白子,一个黑子,下一行放四个黑子,一个百子,然后找题目要求去后续填充即可。

#include<bits/stdc++.h>using namespace std;
const int N=1e5+5;
typedef long long ll;
typedef pair<ll,ll> pll;
int mod=998244353;
const int maxv=4e6+5;void solve()
{	int n,m;cin>>n>>m;if(n%2){for(int i=1;i<=n-1;i++){if(i%2){for(int j=1;j<=m;j++){if(j%5==0) cout<<'o';else cout<<'x';}}else{for(int j=1;j<=m;j++){if(j%5==0) cout<<'x';else cout<<'o';}}cout<<endl;}for(int i=1;i<=m;i++){if(i%2) cout<<'x';else cout<<'o';}cout<<endl;}else{for(int i=1;i<=n;i++){if(i%2){for(int j=1;j<=m;j++){if(j%5==0) cout<<'o';else cout<<'x';}}else{for(int j=1;j<=m;j++){if(j%5==0) cout<<'x';else cout<<'o';}}cout<<endl;}}}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t=1;cin>>t;while(t--){solve();}system("pause");return 0;
}

K.Box

#include<bits/stdc++.h>using namespace std;
const int N=1e6+5;
typedef long long ll;
typedef pair<ll,ll> pll;
int mod=998244353;
const int maxv=4e6+5;ll dp[N][3];
ll a[N],b[N];void solve()
{	int n;cin>>n;vector<int> pos;for(int i=1;i<=n;i++){cin>>a[i];}pos.push_back(0);for(int i=1;i<=n;i++){cin>>b[i];if(b[i]==1) pos.push_back(i);}memset(dp,-0x3f,sizeof dp);if(pos.size()==1){cout<<0<<endl;return ;}if(pos[1]-1>0) dp[1][0]=a[pos[1]-1];if(pos[1]+1<=n) dp[1][2]=a[pos[1]+1];dp[1][1]=a[pos[1]];for(int i=2;i<pos.size();i++){for(int j=0;j<3;j++){for(int k=0;k<3;k++){if(pos[i-1]+k-1<pos[i]+j-1&&pos[i]+j-1<=n){dp[i][j]=max(dp[i][j],dp[i-1][k]+a[pos[i]+j-1]);}}}}int x=pos.size()-1;cout<<max({dp[x][0],dp[x][1],dp[x][2]})<<endl;
}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t;t=1;//cin>>t;while(t--){solve();}system("pause");return 0;
}

 

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

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

相关文章

亚马逊、虾皮、Lazada、速卖通、阿里国际等跨境电商平台怎么获取优质评价?

在跨境电商平台上&#xff0c;产品的评价直接影响卖家账户的评定因素&#xff0c;同时也影响产品页面的曝光量和流量&#xff0c;从而对产品销量产生影响&#xff0c;因此&#xff0c;产品评价的重要性不言而喻&#xff0c;除了产品的图片、描述、详情、广告和站外推广&#xf…

【LeetCode】不同路劲(动态规划)

不同路劲 题目描述算法流程编程代码 链接: 不同路劲 题目描述 算法流程 编程代码 class Solution { public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m 1,vector<int>(n 1));dp[1][0] 1;for(int i 1;i < m;i){for(int j 1;j < n…

嵌入式基础知识-存储器

本篇介绍计算机存储硬件的一些基础知识&#xff0c;在嵌入式开发中&#xff0c;也同样适用。 1 计算机存储结构 存储器是计算机中的重要部件&#xff0c;理想的存储器应该是执行快&#xff0c;容量足&#xff0c;价格便宜等。但实际上&#xff0c;目前无法同时满足这些目标&a…

blender凹凸感和置换形变

一、怎么做出凹凸感 需要三个部分的内容&#xff1a; 1、一个基础的纹理&#xff1a;告诉计算机需要用一个什么样的纹理做凹凸&#xff0c;纹理一般采用黑白&#xff0c;在计算机里面&#xff0c;从 0 - 1之间的值可以用从黑到白之间不同的灰度来表示因此&#xff0c;有一张黑白…

【Java】Spring——创建Spring + 对Spring的存储 /读取对象操作

文章目录 前言一、创建Spring项目二、向Spring容器中存储 Bean 对象三、从Spring容器中读取 Bean 对象得到Spring上下文对象得到 Bean 对象 总结 前言 本人是一个普通程序猿!分享一点自己的见解,如果有错误的地方欢迎各位大佬莅临指导,如果你也对编程感兴趣的话&#xff0c;互…

英语翻译日语翻译待遇哪个好

如今&#xff0c;随着世界联系越来越紧密&#xff0c;市场上对于翻译业务的需求也越来越大。那么&#xff0c;针对比较热门的英语翻译与日语翻译&#xff0c;哪个语言翻译待遇好&#xff1f; 我们知道&#xff0c;英语作为全球使用频率最高的语言&#xff0c;业务量大市场需求大…

【用户体验分析报告】 按需加载组件,导致组件渲染卡顿,影响交互体验?组件拆包预加载方案来了!

首先&#xff0c;我们看一些针对《如何提升应用首屏加载体验》的文章&#xff0c;提到的必不可少的措施&#xff0c;便是减少首屏幕加载资源的大小&#xff0c;而减少资源大小必然会想到按需加载措施。本文提到的便是一个基于webpack 插件与 react 组件实现的一套研发高度自定义…

云原生落地实践的25个步骤

一、什么是云原生&#xff1f; 云原生从字面意思上来看可以分成云和原生两个部分。 云是和本地相对的&#xff0c;传统的应用必须跑在本地服务器上&#xff0c;现在流行的应用都跑在云端&#xff0c;云包含了IaaS,、PaaS和SaaS。 原生就是土生土长的意思&#xff0c;我们在开始…

Swagger之Hello World !

目录 ■1&#xff0e;前言・Swagger介绍 ■2&#xff0e;例子&#xff0c;如果基于Spring Boot项目&#xff0c;实现Swagger---非常简单 2&#xff0e;1&#xff0e;已有的SpringBoot项目 2&#xff0e;2&#xff0e;修改POM文件 2&#xff0e;3&#xff0e;添加Config文件…

DAY01_Spring简介IOC、DI入门案例Bean基础配置Bean实例化Bean生命周期依赖注入(DI配置)

目录 一 Spring1 Spring简介1.1 为什么要学1.2 学什么1.3 怎么学 2 初识Spring2.1 Spring家族2.2 Spring发展史 3 Spring体系结构问题导入3.1 Spring Framework系统架构图3.2 Spring Framework课程学习路线 4 Spring核心概念问题导入4.1 目前我们代码存在的问题4.2 核心概念 二…

分冶算法 剑指 07 重建二叉树 排序算法:剑指45 把数组排成最小的数 10-I 斐波那契数列

来记录几个注意事项 1.vector容器里利用find&#xff08;&#xff09;函数 不同于map&#xff08;map有find方法&#xff09;&#xff0c;vector本身是没有find这一方法&#xff0c;其find是依靠algorithm来实现的。 所以要包含头文件 #include <iostream> #include <…

奔驰CAN FD嵌入式控制器开发硬件设计及应用趋势

CAN FD作为一种性能可靠、功能完善、成本合理的远程网络通信控制方式&#xff0c;集成CAN/CAN FD控制器的MCU、核心板、工控板及物联网解决方案已经被广泛应用到各个控制系统中&#xff0c;例如汽车电子、自动控制、智能大厦、电力系统、能源物流、智慧改装等各个领域。 中国经…

windows编译新版本linphone

目录​​​​​​​ 环境 获取源码(使用5.0.0版本5.3.0-alpha有问题编译不过) 编译环境准备 编译&#xff08;使用ninja&#xff09; 编译&#xff08;不适用使用ninja&#xff09; 报错解决 linphone-desktop是一款基于SIP的标准开源网络电话系统&#xff0c;它使用了Qt…

计算机视觉(五)深度学习基础

文章目录 深度学习基础卷积神经网络与传统神经网络区别深度学习与神经网络的区别 目标函数选择合适的目标函数Softmax层 改进的梯度下降梯度消失的直观解释激活函数学习步长SGD的问题Momentum动量Nesterov MomentumAdagradRMSpropAdam 各种梯度下降算法比较关于算法选择的建议B…

Adobe Camera Raw 常用快捷键

戳下方链接&#xff0c;后台回复“230707PS插件”获取相关插件应用 回复“230708PS插件教程”获取教学链接; 回复“230730camera快捷键”获取快捷键链接。 原文链接&#xff1a;https://mp.weixin.qq.com/s/tVNDBPUtKrUtfGmPKJ0Tdw 目标调整工具 作用WindowsmacOS选取目标调整工…

【Python】Web学习笔记_flask(1)——模拟登录

安装flask pip3 install flask 第一部分内容&#xff1a; 1、主页面输出hello world 2、根据不同用户名参数输出用户信息 3、模拟登录 from flask import Flask,url_for,redirectappFlask(__name__)app.route(/) def index():return hello worldapp.route(/user/<uname…

python爬虫(三)_HTTP的请求和响应

HTTP和HTTPS HTTP(HyperText Transfer Protocol&#xff0c;超文本传输协议)&#xff1a;是一种发布和接收HTML页面的方法 HTTPS(HyperText Transfer Protocol over Secure Socket Layer)简单讲是HTTP的安全版&#xff0c;在HTTP下加入SSL层。 SSL(Secure Socket Layer安全套…

Windows 环境Kubernetes安装

目录 前言 安装 Docker 安装 Kubernetes Windows 安装 kubectl 介绍 安装 开启 Kubernetes 前言 Docker作为当前最流行的容器化平台&#xff0c;为Kubernetes提供了强大的容器化技术基础。Kubernetes与Docker的结合&#xff0c;使得容器化应用程序在大规模集群中得以简…

计算机视觉实验:图像处理综合-路沿检测

目录 实验步骤与过程 1. 路沿检测方法设计 2. 路沿检测方法实现 2.1 视频图像提取 2.2 图像预处理 2.3 兴趣区域提取 2.4 边缘检测 ​​​​​​​2.5 Hough变换 ​​​​​​​2.6 线条过滤与图像输出 3. 路沿检测结果展示 4. 其他路沿检测方法 实验结论或体会 实…

Linux CentOS 8 编译安装Apache Subversion

前言 距离上一篇发表已经过去了5年零2个多月&#xff0c;这次重新开始写技术博客&#xff0c;理由和原来一样&#xff0c;也就是想把自己学习和工作中遇到的问题和知识记录下来&#xff0c;今天记录一下Linux CentOS 8通过编译安装svn的过程。 下载SVN 下载地址&#xff1a;…