博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【推导】【模拟】AtCoder Regular Contest 082 F - Sandglass
阅读量:6632 次
发布时间:2019-06-25

本文共 386 字,大约阅读时间需要 1 分钟。

题意:有个沙漏,一开始bulb A在上,bulb B在下,A内有a数量的沙子,每一秒会向下掉落1。然后在K个时间点ri,会将沙漏倒置。然后又有m个询问,每次给a一个赋值ai,然后询问你在ti时刻,bulb A的沙子数。保证A和B的总沙子数为X。

函数ft(x)表示t时刻,初始bulb A中的沙子数为x时,当前的bulb A中的沙子数是多少。

最开始时函数恰好为f(x)=x。

然后在第一次翻转之前,函数会逐渐向下移动变为<2>的样子,然后在翻转之后,函数又会逐渐向上移动,直至变成<3>、<4>的样子。但是不论怎样移动,上界一定是X,下界一定是0。

于是按照时间去模拟维护这个分段函数即可,分段函数很简单,最多只有两个转折点。

不过时间范围很大,要离散时间。

转载于:https://www.cnblogs.com/autsky-jadek/p/7469390.html

你可能感兴趣的文章
Resharper的使用
查看>>
EF Migrations Command Reference (EF 迁移命令)
查看>>
字节序详解
查看>>
bigdata related
查看>>
第七堂:对象,类
查看>>
计算点在哪些四边形内
查看>>
android开发之android:padding和android:margin的区别
查看>>
写个代码测试一下
查看>>
程序员,该戒烟了
查看>>
C# 使用Nlog记录日志到数据库
查看>>
MongoDB-分片片键
查看>>
SpringCloud的组件和概念介绍
查看>>
Python *Mix_w3
查看>>
lamp环境配置
查看>>
Lua BehaviourTree 各节点说明
查看>>
tttttabs
查看>>
lintcode 主元素解决方法
查看>>
搭建JAVA WEB开发环境(tomcat)
查看>>
打开silverlight项目之前,您需要安装最新的Silverlight Developer运行时
查看>>
最近突然想了很久还是开博每天写点什么
查看>>