ABC268总结

过题情况

AC:6 / 8
排名:215

题目分析

A(语法入门)

判重即可

B(字符串)

看看 s 每一位是否分别对应 t

C(模拟)

计算一下从 i 分别转到 pi1,pi,pi+1 分别要多少步,则当前对这三个选择的贡献加1

最后扫一遍统计最大贡献

D(dfs+哈希)

首先枚举 s 的全排列,然后枚举任意 s 中插入多少个 _,然后再判重

判重的过程直接暴力会爆掉,哈希一下即可

E(模拟+差分)

加入从 ipik 步,则此时它对 k 的代价是0

然后随着步数增长其对当前步数的代价必然是先增大后减小,所以枚举一下转折点,差分一下最后扫一遍即可

细节有点多,主要是要考虑初始状态,维护初始状态的代价和接下来的变化

F(贪心)

显然,块内代价可以预处理

然后我们再处理两个数组 ai,ci,分别代表 SiX 的个数和非 X 数的和

假设最后构造了一种序列 T,考虑相邻两个 Ti,Ti+1 有没有交换的必要

首先这两个如果单独交换对其它 Tj 是没影响的

而原先的贡献是 ai×ci+1,而交换后的代价是 ai+1×ci

由于 T 是最终构造序列,所以必然满足 ai×ci+1ai+1×ci

移项得 aiciai+1ci+1

由于任意相邻两项都符合这个原则,所以按 aici 从大到小排序即可

posted @   zhangtingxi  阅读(176)  评论(2编辑  收藏  举报
相关博文:
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
点击右上角即可分享
微信分享提示