【题解】 CF1086F 分析 插值 扫描线
首先 观察这个时间巨大无比,所以考虑基于离散的东西去统计它。
让 表示时间 的燃烧区域大小。 则可以先求出最后的燃烧区域大小 ,答案为 。
考虑只有一个块形态没有发生改变的块的一段时间内怎么统计。
对于一个块,每次 的增加量就是 ,而 在形态没有改变的时候是不变的,边数的增加量只与目前边数相关,而边数的增长是线性的,只有在角处会多出或减少一条边。
那么 是一个二次函数。
我们可以将时间分成 段,每段图形都没有发生新的形状改变,因为图形发生形状的改变本质是“角”之间的位置关系的改变,就是两个初始燃烧点对应的扩展区域的横坐标或者纵坐标从不交变得相交。
然后求出每个时间段内的二次函数的式子,如果要算内角和外角的数量比较复杂,还会涉及到图形的封闭与开放,不如直接求三个值,然后做插值求出二次函数的式子,再做求和。
求单个 值可以用扫描线做到 ,时间复杂度 。
做完了才发现是 *3500,很高兴。虽然是 *3500,但是思路很自然,尤其是当对某个函数求值,而定义域较大时,考虑插值,而本题图形的性质可以让函数呈现为分段函数,很精妙。
本文已经结束了。本文作者:ღꦿ࿐(DeepSea),转载请注明原文链接:https://www.cnblogs.com/Dreamerkk/p/17970917,谢谢你的阅读或转载!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步