http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4056

题意

有一个按钮、一个灯、一个计时器和一个计数器,每按一次按钮,计时器被置为v+0.5,若当前灯是灭的,按一次后变亮,若当前灯是亮的,按一次后计数器+1,若当前时间nt%a=0,则按b次按钮,若nt%c=0,则按d次按钮,问最后时间为t时,计数器的值

分析

通过分析可以发现,每lcm(a,c)个时间构成一个循环,所以只需要求出每个lcm(a,c)的贡献,作为一段,再求出共有多少段即可,最后余下部分不足一段再单独处理,需要注意的是几个边界情况,t=0时灯是灭的,所以第一段一定是以灯熄灭状态为起始条件,但后面的段可能以灯亮着状态为起始条件,这样整体就会差1。
再分析会发现,对于每一段,我们根本不用求出具体贡献,只要先假设灯一直是亮的,求出全部贡献,再求出灯熄灭了多少次就行,每熄灭一次counter数就要-1
可以得到这样的公式:(t/a)*b+(t/c)*d+b+d-1 ,即表示从0~t时刻,假设灯一直是亮的,按钮被按下的次数,因为实际t=0时灯是灭的,就相当于少按了一次按钮
然后减去每一段灯熄灭的次数,再处理下结尾部分即可

#include <bits/stdc++.h>
using namespace std; typedef long long LL;
vector<long long>Q;
long long a,b,c,d,v,t;
long long pt,cntt;
LL gcd(LL a,LL b){ //最大公约数if(b==) return a;
else return gcd(b,a%b);
} LL lcm(LL a,LL b){ //最小公倍数return a/gcd(a,b)*b; //防止溢出
}
void getblock(){ //得到每一段的贡献,即一段中灯熄灭次数
pt=lcm(a,c);
cntt=;
Q.clear();
for(LL i=;i<=pt;i+=a) Q.push_back(i);
for(LL i=;i<=pt;i+=c) Q.push_back(i);
sort(Q.begin(),Q.end());
Q.erase(unique(Q.begin(),Q.end()),Q.end()); //去重 for(int i=;i<Q.size();i++){
if(Q[i]-Q[i-]>v) //前后差大于v,即表示灯熄灭
cntt++;
}
}
int main(){
std::ios::sync_with_stdio(false);
int cnt;
cin>>cnt;
while(cnt--){
cin>>a>>b>>c>>d>>v>>t;
getblock();
long long ans=(t/a)*b+(t/c)*d+b+d-; //从0~t按下的次数
long long blk=t/pt; //共有blk段
ans=ans- blk*cntt; //减去每段中灯熄灭的次数
long long last=t%pt; //最后不足一段时的边界
for(LL i=;Q[i]<=last;i++) //单独处理最后不足一段部分
if(Q[i]-Q[i-]>v) ans--;
cout<<ans<<endl;
}
return ;
}

The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J - Press the Button(思维)的更多相关文章

  1. The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J Press the Button

    BaoBao and DreamGrid are playing a game using a strange button. This button is attached to an LED li ...

  2. The 2018 ACM-ICPC Asia Qingdao Regional Contest(部分题解)

    摘要: 本文是The 2018 ACM-ICPC Asia Qingdao Regional Contest(青岛现场赛)的部分解题报告,给出了出题率较高的几道题的题解,希望熟悉区域赛的题型,进而对其 ...

  3. The 2018 ACM-ICPC Asia Qingdao Regional Contest

    The 2018 ACM-ICPC Asia Qingdao Regional Contest 青岛总体来说只会3题 C #include<bits/stdc++.h> using nam ...

  4. ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków

    ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków Problem A: Rubik’s Rect ...

  5. 2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred)

    2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred) easy: ACE ...

  6. The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online -C:Halting Problem(模拟)

    C Halting Problem In computability theory, the halting problem is the problem of determining, from a ...

  7. The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online Solution

    A    Live Love 水. #include<bits/stdc++.h> using namespace std; typedef long long ll; ; const i ...

  8. 2018-2019, ICPC, Asia Yokohama Regional Contest 2018 K

    传送门:https://codeforces.com/gym/102082/attachments 题解: 代码: /** * ┏┓ ┏┓ * ┏┛┗━━━━━━━┛┗━━━┓ * ┃ ┃ * ┃ ━ ...

  9. ZOJ - 4048 Red Black Tree (LCA+贪心) The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online

    题意:一棵树上有m个红色结点,树的边有权值.q次查询,每次给出k个点,每次查询有且只有一次机会将n个点中任意一个点染红,令k个点中距离红色祖先距离最大的那个点的距离最小化.q次查询相互独立. 分析:数 ...

随机推荐

  1. ubuntu18.04 ssh 远程系统拒绝连接 解决方法

    错误提示是这个: The remote system refused the connection. 原因是 Ubuntu 没安装  一个软件, 废话不多说 ,上解决方法: 执行该条命令,安装 ,安装 ...

  2. 随机IP

    function rand_ip(){ $ip_longs = array( array('607649792', '608174079'),        //36.56.0.0-36.63.255 ...

  3. Linux(CentOS7)压缩和解压缩war包、tar包、tar.gz包命令

    一.Linux版本 二.解压缩.tar.gz包到当前目录 tar -xzvf apache-tomcat-7.0.90.tar.gz 三.将指定文件压缩成.tar.gz包 tar -czf apach ...

  4. Scrapy框架-Item Pipeline

    目录 1. Item Pipeline 3. 完善之前的案例: 3.1. item写入JSON文件 3.2. 启用一个Item Pipeline组件 3.3. 重新启动爬虫 1. Item Pipel ...

  5. 百度地图引用时 报出A Parser-blocking, cross site (i.e. different eTLD+1) script

    页面引入百度地图api时 chrome控制台报出警示问题 A Parser-blocking, cross site (i.e. different eTLD+1) script, http://ap ...

  6. 第二课android中activity启动模式

    一.标准启动模式可以用函数gettaskid得到任务的idtostring得到地址用textallcaps来设置是否全部大写应用启动自己是在任务栈里创建不同实例可以用返回来返回上一个任务栈在andro ...

  7. vue 父子之间的通讯

    //父组件<template>     <Button @click='openChild'><Button>      <child-modal :moda ...

  8. nginx基础之【study one】

    Nginx是种代理服务器,即可以作为反向代理服务器.邮件服务器等HTTP服务器,支持很多第三方模块扩展,如GZip.SSL.FastCGI. 最常用的功能有Http反向代理.负载均衡和Web缓存: 1 ...

  9. 初学tensorflow遇到的Error——UnrecognizedFlagError: Unknown command line flag 'f'

    最近在学习<tensorflow实战>时需要下载cifar10数据集,在cifar10目录下用到命令: import cifar10,cifar10_inputcifar10.maybe_ ...

  10. Shodan的http.favicon.hash语法详解与使用技巧

    在Shodan搜索中有一个关于网站icon图标的搜索语法,http.favicon.hash,我们可以使用这个语法来搜索出使用了同一icon图标的网站,不知道怎么用的朋友请参考我上一篇文章. 通过上一 ...