粒子消消乐

news/2024/9/24 20:16:18/文章来源:https://www.cnblogs.com/watersail/p/18429922
  • 跳跃的过程往往可以用倍增优化
  • 【发散思维】根据鸽巢原理,最后剩下的粒子至多26个,但直接从这一点入手不好做。从这一条性质出发,我们还能推出什么?剩下的粒子两两之间被消掉的段数是有限的!
  • 26*19看起来挺大的,但其实不就是log^2嘛!有2s时限,n=200000完全可过的
点击查看代码
#include <bits/stdc++.h>
using namespace std;
char s[400005];
int f[400005][19],b[400005],g[400005];
int la[105];
int n,q;
void pre()
{for(int j=1;j<=18;j++){for(int i=1;i<2*n;i++){if(f[i][j-1]==-1){f[i][j]=-1;}else{f[i][j]=f[f[i][j-1]][j-1];}if(f[i][j]!=-1){g[i]=j;}}}
}
void refresh()
{for(int j=0;j<=18;j++){for(int i=1;i<2*n;i++){f[i][j]=-1;}}
}
int main()
{ios::sync_with_stdio(false);cin.tie(0);memset(f,-1,sizeof(f));int T;cin>>T;while(T--){cin>>n>>q;for(int i=1;i<=n;i++){cin>>s[i];s[i+n]=s[i];}for(int i=1;i<=n;i++){cin>>b[i];b[i+n]=b[i];}memset(la,0,sizeof(la));for(int i=1;i<2*n;i++){f[i][0]=-1;g[i]=-1;}for(int i=1;i<2*n;i++){f[la[s[i]]][0]=i+1;g[la[s[i]]]=0;la[s[i]]=i;}pre();for(int i=1;i<=q;i++){int opt,u,v;cin>>opt>>u>>v;if(opt==1){b[u]=b[u+n]=v;}else{if(u>v){v+=n;}int p=u;long long ans=0;while(p<=v){if(g[p]==-1||f[p][0]>v+1){ans+=b[p];p++;continue;}for(int j=g[p];j>=0;j--){if(f[p][j]!=-1&&f[p][j]<=v+1){p=f[p][j];}}}cout<<ans<<endl;}    }refresh();}return 0;
}

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

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

相关文章

任务4:制作二维码

该二维码链接到游戏“植物大战僵尸”,寓教于乐。 提升趣味性和互动性的同时,学生们参与到课堂当中,发挥主体作用,感受到自然界植物的多样性,对土壤的作用有了更深刻的理解。

封装的练习题目1

1.使用面向对象的思想,编写自定义描述狗的信息。设定属性包括:品种,年龄,心 情,名字;方法包括:叫,跑。 要求: 1)设置属性的私有访问权限,通过公有的 get,set 方法实现对属性的访问 2)限定心情只能有“心情好”和“心情不好”两种情况,如果无效输入进行提示, 默认…

五款免费可视化工具全解析:选择你的最佳搭档

1. 山海鲸可视化 介绍: 山海鲸可视化是一款免费的国产可视化报表软件,与许多其他宣传免费的软件不同,山海鲸的报表功能完全免费并且没有任何限制,就连网站管理后台这个功能也是免费的。同时山海鲸可视化还提供了种类丰富的可视化图表、三维模型、模板可供使用,软件采用点击…

408OS_PV操作大题总结

咸鱼今年压了读者写者问题,前几年没考过。死锁的四个条件是:禁止抢占(no preemption):系统资源不能被强制从一个线程中退出。 持有和等待(hold and wait):一个线程在等待时持有并发资源。持有并发资源并还等待其它资源,也就是吃着碗里的望着锅里的。 互斥(mutual exc…

2024.9.24 思维导图与PDF

哈哈哈终于有我也用过的东西啦~Xmind一款打工人用了都说好的软件(#.#) 【知识小课堂1】不同款式的思维导图:【知识小课堂2】PDF转换器! 1、PDF(便携式文档格式),这种文件格式与操作系统平台无关 —— PDF文件不管是在Windows还是别的操作系统中都是通用的。 2、这一特点使它…

如何设计一个伪无埋点的框架?

主要基于无埋点的缺点,来设计一个伪无埋点的框架,使得业务既可以拥有无埋点的特性,又能满足业务的数据分析需求本文同步发布于公众号:移动开发那些事如何设计一个伪无埋点的框架 在前面的文章:Android无埋点技术概览 中提到传统的无埋点有几大缺点:埋点字段有限,没有办法…

吴恩达机器学习课程 笔记4 分类 逻辑回归

逻辑回归 机器学习中的逻辑回归(Logistic Regression)是一种广泛使用的分类算法,尽管它的名字中包含“回归”这个词,但实际上它主要用于解决分类问题,特别是二分类问题。逻辑回归模型可以用来预测某一类事件发生的概率,例如预测用户是否会点击广告、病人是否患有某种疾病…

设计模式之中介模式(三分钟学会一个设计模式)

中介模式(Mediator)又称之为调停模式。mediator [ˈmiːdieɪtə(r)] n. 调停者;斡旋者;解决纷争的人(或机构); 本意就是解决纠纷的中间人它是面向对象六大原则中最少知道原则的一个典型应用。(关于面向对象六大原则,可看前文:https://www.cnblogs.com/jilodream/p/535351…

Large Vision Model

LVM https://yutongbai.com/lvm.html https://zhuanlan.zhihu.com/p/671423679Large Vision Model(简称LVM)是一种纯粹基于视觉数据进行训练和推理的大型模型,其特点在于无需涉及任何自然语言输入或输出。该模型的提出源自一篇由UC Berkeley的三位计算机视觉专家联合撰写的论…

2024 天池云原生编程挑战赛决赛名单出炉,冠军来自中山大学、昆仑数智战队

9 月 20 日,2024 天池云原生编程挑战赛决赛答辩完美落幕,12 支进入决赛的团队用精彩的答辩,为历时 3 个月的大赛画下了圆满的句号。其中,来自中山大学的陈泓仰以及来自昆仑数智的冉旭欣、沈鑫糠、武鹏鹏,以出色的方案、创新的优化思路、过硬的技术实力分获赛道一和赛道二的…