2023牛客暑期多校训练营7(C/I/M)
目录
C.Beautiful Sequence
I.We Love Strings
M.Writing Books
C.Beautiful Sequence
思路:显然若得到了a[1],则整个序列a我们都知道了。所以我们要求出第k大的a[1],这个可以利用序列a为不递减序列的性质来得出。
首先,由题意可得:
a[2]=a[1]^b[1]
a[3]=a[2]^b[2]=(a[1]^b[1])^b[2]
a[4]=a[3]^b[3]=((a[1]^b[1])^b[2])^b[3]
......
得出a[i]=a[1]^(序列b的前缀i异或和)
我们把序列b的前缀i异或和定义为f[i],因为序列a不递减,所以:
a[i]<=a[i+1]
=> a[1]^f[i-1] <= a[1]^f[i]
首先我们先初始化a[1]二进制位为-1,这代表a[1]的这个位可以是0,也可以是1。然后我们再根据a[1]^f[i-1] <= a[1]^f[i] 这个公式来得出a[1]的哪些位它是确定的,不能是-1。
我们需要从高位往低位贪心,因为如果a[1]^f[i-1]的一个高位如果是1,而a[1]^f[i]的这个位是0,那么低位再怎么变,a[1]^f[i-1]也必然小于a[1]^f[i]。比如两个二进制数1????和0????,就算左边的低位全是1,右边的高位全是0,也就是变成10000和01111,左边依然大于右边。
然后我们从高位到低位怎么贪心呢?找f[i]的f[i-1]的从高位到低位,第一个不同的位即可,我们设这个是第k位。此时a[1]的第k位必须和f[i]第k位的值相同,这样子就能让f[i]^a[1]的第k位是0,f[i+1]^a[1]第k位是1,保证了前者小于后者。在此之前a[i]的第k位必须等于-1或者等于f[i]的第k位,否则输出-1。
此时我们得到了n个-1的值,我们我们最多能表示第2的n次方大的值,此时我们只需将(k-1)拆分成二进制依次填入-1的位置即可。具体实现见代码。
代码:
void solve() {a[1]=0;mem(now,-1);int n,k;cin>>n>>k;for(int i=1; i<n; i++) {cin>>b[i];f[i]=(f[i-1]^b[i]);}for(int i=0; i<n-1; i++) {for(int j=29; j>=0; j--) {if((f[i]>>j&1ll)!=(f[i+1]>>j&1ll)) {//找到高位第一个不相等的二进制位if(now[j]==-1)now[j]=(f[i]>>j&1ll);else if(now[j]==(f[i+1]>>j&1ll)) {//如果该位已经确定,并且与想要填的数相反,则输出-1cout<<-1<<endl;return;}break;//高位比上一个大了之后,就不用再管低位了}}}k--;//去掉初始不变的情况,方便替换-1int maxx=0;for(int i=0; i<30; i++) {if(now[i]==-1)maxx=maxx*2+1;}if(maxx<k) {cout<<-1<<endl;return;}vector<int>v;while(k) {//将k转换为二进制填入v.push_back({k%2});k/=2;}reverse(v.begin(),v.end());for(int i=0; i<30; i++) {if(!v.size())break;//填完了就退出if(now[i]==-1) {//依次填入now[i]=v.back(),v.pop_back();}}for(int i=0; i<30; i++)now[i]=max(now[i],0ll);//把没填的-1变成0for(int i=29; i>=0; i--) a[1]=a[1]*2+now[i];;//得出a[1]的值cout<<a[1]<<" ";for(int i=2; i<=n; i++)cout<<(b[i-1]^a[i-1])<<" ",a[i]=(b[i-1]^a[i-1]);//根据a[1]得出整个序列acout<<endl;
}
I.We Love Strings
思路:因为字符串长度不相同的字符串,两两之间肯定不能匹配,所以我们根据字符串长度大小来求解。在lenth<=20时我们暴力枚举字符串所有情况进行求解,而在lenth>20的时候我们暴力容斥来求解。
那么为什么这个临界值为20呢?
我们设临界值为N,暴力枚举所有情况的复杂度主要由字符串长度决定,复杂度为:

而容斥的复杂度主要由容斥的集合大小决定,而这个集合的最大大小又由n的最大值和N共同决定,它的复杂度为:

总的复杂度为他们两个相加。
此时N取太大或者取太小,都会使得一方的复杂度过大,此时取400的根号,也就是N=20,是最好的。
具体实现见代码。
代码:
int pp(vector<int>v,string s,int n) {for(int i=0; i<n; i++) {if(s[i]!='?'&&v[i]!=s[i]-'0')return 0;//如果两个串确定有位置不同了,则匹配失败 }return 1;//匹配成功
}
int f1(int n) {int sum=0;for(int i=0; i<(1<<n); i++) {//枚举这个长度01串的所有可能。 vector<int>s;for(int j=0; j<n; j++) {s.push_back((i>>j&1ll));} //将枚举的串存入vector for(int i=0; i<v[n].size(); i++) {if(pp(s,v[n][i],n)) {//如果有一个串能和这个枚举的串匹配,答案+1 sum++;break;}}}return sum;
}
int f2(int n) {int m=v[n].size(),ans=0;//注意i要从1开始,若从0开始则会使答案增加 for(int i=1; i<(1ll<<m); i++) {//枚举集合内的串int sum=1;for(int j=0; j<n; j++) {//枚举串的每个位 int cnt0=0,cnt1=0;for(int k=0; k<m; k++) {//表示这是集合内第几个串 if((i>>k&1ll)) {if(v[n][k][j]=='0')cnt0++;if(v[n][k][j]=='1')cnt1++;}}if(cnt0&&cnt1) {//若该位上确定的数不一致,则不能进行容斥 sum=0;break;}if(!cnt0&&!cnt1)sum=sum*2%mod;//该位上全是?,贡献*2 }int now=__builtin_popcount(i); if(now%2)ans=(ans+sum)%mod; //进行容斥 else ans=(ans-sum+mod)%mod;}return ans;
}
void solve() {int n,ans=0;cin>>n;for(int i=1; i<=n; i++) {string s;cin>>s;v[(int)s.size()].push_back(s);//将字符串根据长度分类 }for(int i=1; i<=400; i++) {if(!v[i].size())continue;if(i<=20)ans=(ans+f1(i))%mod;//若长度<=20则暴力求解 else ans=(ans+f2(i))%mod;//否则暴力容斥 }cout<<ans<<endl;
}
M.Writing Books
思路:显然1~9对于答案的贡献为1*9,10~99对于答案的贡献为2*90,100~999对于答案的贡献为3*900......。分块求出贡献即可。
代码:
void solve() {int n,l=1,r=10,now=1,ans=0;cin>>n;while(l<=n){if(n>=r-1)ans+=(r-l)*now;else ans+=(n-l+1)*now;now++,l=r,r*=10;}cout<<ans<<endl;
}
相关文章:
2023牛客暑期多校训练营7(C/I/M)
目录 C.Beautiful Sequence I.We Love Strings M.Writing Books C.Beautiful Sequence 思路:显然若得到了a[1],则整个序列a我们都知道了。所以我们要求出第k大的a[1],这个可以利用序列a为不递减序列的性质来得出。 首先,由题…...
阿里云服务器手动搭建FTP教程(Windows操作系统)
阿里云百科介绍使用阿里云服务器搭建FTP教程,云服务器为Windows操作系统,当需要远程连接Windows实例进行文件传输时,可以通过搭建FTP站点实现。本文将介绍如何在Windows实例中搭建FTP站点。 目录 准备工作 步骤一:添加IIS以及F…...
idea+gradle阅读spring5.2.9源码之源码构建报错解决方案
注意 1、先确保gradle版本和spring、jdk版本对应 本文:gradle:5.6.4/spring 5.2.9/jdk1.8(gradle和jdk都要先安装好,gradle还要配置好本地资源文件路径) 2、原来项目乱了的话,先重新导入下载的源码项目 3、进入源码所在根目录&…...
一文详解Git
一. Git 概述 1.1 什么是 Git Git 是一个免费的、开源的分布式版本控制工具, 主要用于管理开发过程中的源代码文件,在软件开发过程中被广泛使用。通过Git仓库来存储和管理这些文件,Git仓库分为二种: 本地仓库:开发人…...
【单片机】DS2431英文手册,中文手册,翻译
DS2431是一款1024位的1-Wire EEPROM芯片,以每个256位的四个内存页面组织。数据被写入8字节的暂存区,经过验证,然后复制到EEPROM存储器中。作为一个特殊功能,四个内存页面可以单独地被写保护,或者被置于EPROM仿真模式&a…...
centos7部署openldap开启memberof并接入jumpserver
文章目录 前言1.yum安装openldap2.配置密码3.导入配置4.定义域5.配置memberof6.配置base dn7.安装phpldapadmin管理8.调整httpd的配置9.调整php的配置10.登陆php管理页面11.同步旧ldapsever用户数据(可省略)12.客户端配置13.对接jumpserver 前言 介绍如何在centos7上部署openl…...
Unity游戏源码分享-仿开心消消乐Match3Jewel
Unity游戏源码分享-仿开心消消乐Match3Jewel 工程地址: https://download.csdn.net/download/Highning0007/88198762...
知识图谱基本工具Neo4j使用笔记 四 :使用csv文件批量导入图谱数据
文章目录 一、系统说明二、说明三、简单介绍1. 相关代码以及参数2. 简单示例 四、实际数据实践1. 前期准备(1) 创建一个用于测试的neo4j数据库(2)启动neo4j 查看数据库 2. 实践(1) OK 上面完成后࿰…...
[bug修复]状态数据在useEffect初始化时更新无效
(bug修复类型的博客还是用汉语写捏) 前两天在做一个管理页面前端的时候,出现了这样的问题 function Son(props){const [a,seta]useState(0)useEffect(()>{seta(props.name)},[])return(<div>{a}</div>) } 这是当时情况的一…...
使用 API Gateway Integrator 在 Quarkus 中实施适用于 AWS Lambda 的 OpenAPI
AWS API Gateway 集成使得使用符合 OpenAPI 标准的 Lambda Function 轻松实现 REST API。 关于开放API 它是一个 允许以标准方式描述 REST API 的规范。 OpenAPI规范 (OAS) 为 REST API 定义了与编程语言无关的标准接口描述。这使得人类和计算机都可以发现和理解服务的功能&am…...
【JVM】JVM中的分代回收
文章目录 分代收集算法什么是分代分代收集算法-工作机制MinorGC、 Mixed GC 、 FullGC的区别是什么 分代收集算法 什么是分代 在java8时,堆被分为了两份: 新生代和老年代【1:2】 其中: 对于新生代,内部又被分为了三…...
C# Linq源码分析之Take方法
概要 Take方法作为IEnumerable的扩展方法,具体对应两个重载方法。本文主要分析第一个接收整数参数的重载方法。 源码解析 Take方法的基本定义 public static System.Collections.Generic.IEnumerable Take (this System.Collections.Generic.IEnumerable source…...
从后往前读取列表的方法
从后往前读取列表的方法 方法1:使用for循环遍历列表时,可以使用reverse()函数将列表反转,然后再遍历。 # 列表 num [0, 1, 2, 3]# 反向遍历 for i in reversed(num):print(i)输出结果: 3 2 1 0方法2:先计算列表长度…...
数据库--数据类型
数据库相关链接: 数据库基础操作--增删改查:http://t.csdn.cn/189CF 数据库--三大范式、多表查询、函数sql:http://t.csdn.cn/udJSG 数据类型 创建表的时候,我们在类型这里给出了不同的选项,比如有int ,…...
小型双轮差速底盘机器人实现红外跟随功能
1. 功能说明 本文示例将实现R023样机小型双轮差速底盘跟随人移动的功能。在小型双轮差速底盘前方按下图所示安装3个 近红外传感器,制作一个红外线发射源,实现当红外发射源在机器人的检测范围内任意放置或移动时,机器人能追踪该发射源。 2. 电…...
TCP协议网络编程 回显服务器,客户端实现
回显服务器表示客户端传来的请求是什么,服务器就回应什么,客户端不用对传来的数据进行处理,主要是为了熟悉TCP协议提供的API的使用 对于代码的解释全作为注释写在了代码上,推荐复制到编程软件中查看 UDP协议实现回显服务器可以看…...
3.4 Spring MVC注解
注解名称 注解说明 RequestMapping 用来处理请求地址映射的注解,可以在接口、类和方法上使用 value属性 表示请求地址,与path属性一致 method属性 表示接收HTTP请求方法,默认接收所有请求方法,请求包括GET、POST、PUT、DEL…...
OpenCV实例(八)车牌字符识别技术(三)汉字识别
车牌字符识别技术(三)汉字识别 1.代码实例2.遇到问题3.汉字识别代码实例 相较于数字和英文字符的识别,汽车牌照中的汉字字符识别的难度更大,主要原因有以下4个方面: (1)字符笔画因切分误差导致非笔画或笔画流失。 (2…...
运维监控学习笔记2
硬件监控: 1)使用IPMI 2)机房巡检 路由器和交换机: 使用SNMP(简单网络管理协议)进行监控。 Linux 安装snmp: yum install -y net-snmp net-snmp-utils 说明:net-snmp是安装在snm…...
【深度学习】遗传算法[选择、交叉、变异、初始化种群、迭代优化、几何规划排序选择、线性交叉、非均匀变异]
目录 一、遗传算法二、遗传算法概述2.1 选择2.2 交叉2.3 变异 三、遗传算法的基本步骤3.1 编码3.2 初始群体的生成3.3 适应度评估3.4 选择3.5 交叉3.6 变异3.7 总结 四、遗传算法工具箱4.1 initializega4.2 ga4.3 normGeomSelect4.4 arithXover4.5 nonUnifMutation 五、遗传算法…...
基于海外数据本地化政策的边缘计算网关脱敏架构与Python实战
摘要: 随着储能系统在全球范围的大规模部署,海外监管机构对工业互联网接入层的数据出境合规与隐私审查愈发严厉。忽视边缘端的数据本地化处理不仅会导致并网测试挂科,更可能引发巨额罚款。本文从底层研发架构师视角出发,深度拆解符…...
Visual C++运行库整合安装器:告别繁琐安装的一站式解决方案
Visual C运行库整合安装器:告别繁琐安装的一站式解决方案 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经因为"缺少MSVCP140.dll&quo…...
Fairseq-Dense-13B-JanewayGPU算力:实测13B模型在4090D上达9.2 tokens/s吞吐性能
Fairseq-Dense-13B-JanewayGPU算力:实测13B模型在4090D上达9.2 tokens/s吞吐性能 1. 模型概述 Fairseq-Dense-13B-Janeway是由KoboldAI发布的130亿参数创意写作大模型,专注于生成具有经典叙事风格的英文科幻与奇幻内容。该模型基于2210本科幻与奇幻题材…...
突破性小红书数据洞察引擎:从技术难题到商业价值的创新实践
突破性小红书数据洞察引擎:从技术难题到商业价值的创新实践 【免费下载链接】xhs 基于小红书 Web 端进行的请求封装。https://reajason.github.io/xhs/ 项目地址: https://gitcode.com/gh_mirrors/xh/xhs 在当今数据驱动的商业环境中,小红书平台已…...
RePKG终极指南:5分钟掌握Wallpaper Engine资源处理技巧
RePKG终极指南:5分钟掌握Wallpaper Engine资源处理技巧 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 你是否曾经遇到过想要修改Wallpaper Engine壁纸中的某个元素&…...
年薪百万消失!提示词工程 dead?揭秘驾驭AI的真正密码:上下文与治理框架
2023年,“年薪百万招提示词工程师”刷爆全网。大家以为找到了通往未来的金饭碗。 一眨眼的功夫,这个岗位几乎绝迹。 为什么?因为企业花大价钱发现,靠写“小作文”哄着 AI 干活,根本做不出能赚钱的商业产品。聪明绝顶的…...
Real-Anime-Z社区项目实战:仿黑马点评的动漫作品分享社区构建
Real-Anime-Z社区项目实战:仿黑马点评的动漫作品分享社区构建 1. 项目背景与核心价值 最近在技术社区里看到一个很有意思的现象:AI生成内容正在从单纯的工具属性,逐步向社交化、平台化方向发展。这让我想起几年前参与过的一个类似黑马点评的…...
【Loom响应式避坑红宝书】:基于JDK21.0.3+Spring Boot 3.2.8生产环境实测,仅剩最后237份内部调试日志样本
第一章:Loom响应式编程转型的必要性与风险全景图现代服务端应用正面临高并发、低延迟与资源效率三重压力。传统基于线程池的阻塞式I/O模型在处理数万级并发连接时,因线程栈开销(默认1MB/线程)和上下文切换成本,极易触发…...
手机存储速度翻倍的秘密:一文读懂UFS 2.2协议中的MIPI UniPro层
手机存储速度翻倍的秘密:一文读懂UFS 2.2协议中的MIPI UniPro层 当你在旗舰手机上秒开《原神》、连拍100张4800万像素照片却毫无卡顿时,背后是UFS 2.2存储协议与MIPI UniPro层的精密协作。这个藏在闪存芯片里的交通指挥系统,通过独特的CPort连…...
量子纠错解码器:速度与精度的动态平衡方案
1. 量子纠错解码器的核心挑战 在构建实用化容错量子计算机的道路上,量子纠错(QEC)技术扮演着关键角色。作为QEC系统的核心组件,实时解码器负责持续处理量子设备产生的纠错数据(称为"症候群")&…...
