2020 ICPC 沈阳站 I - Rise of Shadows 题解
\(PS\):符号 \([\ \rm P\ ]\) 的意义是:当表达式 \(\rm P\) 为真则取值为 \(1\),为假则取值为 \(0\)。
题目大意
给你一个一天有 \(H\) 小时、一小时有 \(M\) 分钟的表和一个正整数 \(A\),问一天内有多少个整数时刻,使得分针与时针的夹角小于等于 \(\displaystyle\frac{2\pi A}{HM}\)。
题目分析
易知分针转速 \(w_1=\displaystyle \frac{2\pi}{M}\),时针转速 \(w_2=\displaystyle\frac{2\pi}{HM}\),设当前时刻为 \(T\);
一天有 \(HM\) 个整数时刻,即 \(T\in[0,HM)\);
于是对于每一个时刻,我们判断一下两个指针的夹角 \(\theta\) 是否小于等于 \(\displaystyle\frac{2\pi A}{HM}\) ,满足就贡献加加,最后输出总贡献即可。
方法一:数论
对于任意时刻 \(T\) 与两指针间的夹角 \(\theta\),显然有:
\]
注意到 \(\theta\in[0,2\pi]\),所以还要对 \(2\pi\) 取个模(分针转一圈又转回来了),即:
\]
同时因为两个指针之间的夹角可以选到两个数值,逆时针转有一个夹角,顺时针转有一个夹角,这里我们肯定是选更小的角来判断是否满足条件,即最终我们要求的是:
\]
可以转化为:
\]
把 \(\theta=\displaystyle\frac{2\pi(H-1)T}{HM}\mod{2\pi}\) 代入并化简得:
\]
此时我们其实就可以把 \(HM\) 看作是 \(2\pi\),\(H-1\) 看作是每过一个时刻两个指针夹角的变化量,然后分两种情况考虑:
一、当 \(\mathbf {A=HM/2}\) 时,问题等价于”一天内有多少个整数时刻,使得分针与时针的夹角小于等于 \(\pi\)“,显然每个时刻都满足(如果顺时针看夹角大于 \(\pi\),那逆时针看一定小于,反之亦然),此时答案为 \(HM\),特判即可;
二、当 \(\mathbf {A\neq HM/2}\) 时,若有 \(T(H-1)\mod{HM}\leq A\),则一定不会有 \(T(H-1)\mod{HM}\geq HM-A\),所以答案就是这两部分的贡献相加。
我们令 \(G=\gcd(H-1,HM)\)。
先计算式子的左边:
\]
当 \(G=1\) 时 ,因为 \(T\in[0,HM)\),构成了一个模 \(HM\) 的完全剩余系,由完全剩余系的性质可得 \(T(H-1)\mod{HM}\) 也是一个完全剩余系,即它一定取遍了 \(0\sim HM-1\) 的每一个数,此时我们就不用关心到底在哪个时刻造成了贡献,只需知道范围内有多少个数满足小于等于 \(A\) 即可,显然有 \(0\sim A\) 总共 \(A+1\) 个数满足,因此这部分的贡献就是 \(A+1\)。
当 \(G\neq1\) 时,我们利用同余的另一个性质: \(\displaystyle ac\equiv bc\pmod d\iff a\equiv b\pmod{\frac{d}{(c,d)}}\),把式子转化为:
\]
相当于我们把 \(T\in[0,HM)\) 平均分成了 \(G\) 段,每一段的 \(T\) 都构成了一个模 \(\displaystyle\frac{HM}{G}\) 的完全剩余系,此时这里的每一段其实就等价于上面 \(G=1\) 的情况,只是 \(T\) 的范围和模数变了下而已,因此每段都造成了 \(\displaystyle \lfloor\frac AG\rfloor+1\) 的贡献,左边的总贡献就是 \(G*(\displaystyle \lfloor\frac AG\rfloor+1)\)。
再看式子右边:
\]
同样地,当 \(G=1\) 时,跟上面一样分析一波,发现其实是一样的思路(显然左边跟右边造成的贡献是对称的),只不过因为 \(T\) 不能取到 \(HM\),所以贡献只有 \(A\)(\(HM-A\sim HM-1\) 共有 \(A\) 个数)。
当 \(G\neq1\) 时,也同上,把 \(T\) 分成 \(G\) 段,右边的总贡献就是 \(G*\displaystyle \lfloor\frac AG\rfloor\)。
因此最终答案就是左边贡献和右边贡献之和,即 \(G*(\displaystyle 2\lfloor\frac AG\rfloor+1)\)。
Code
#include<bits/stdc++.h>
using namespace std;
int main(){
long long H,M,A;
cin >> H >> M >> A;
if(H*M==A*2){
cout << H*M;
}
else {
long long G=__gcd(H-1,H*M);
cout << G*(2*(A/G)+1);
}
}
方法二:类欧几里得
待填坑~~

2020 ICPC 沈阳站 I - Rise of Shadows 题解的更多相关文章
- 2016 ACM/ICPC 沈阳站 小结
铜铜铜…… 人呐真奇怪 铁牌水平总想着运气好拿个铜 铜牌水平总想着运气好拿个银 估计银牌的聚聚们一定也不满意 想拿个金吧 这次比赛挺不爽的 AB两道SB题,十分钟基本全场都过了 不知道出这种题有什么意 ...
- HDU 5950Recursive sequence ICPC沈阳站
Recursive sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ...
- 2015 ICPC 沈阳站M题
M - Meeting Time Limit:6000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Submit ...
- 2016ACM/ICPC亚洲区沈阳站-重现赛赛题
今天做的沈阳站重现赛,自己还是太水,只做出两道签到题,另外两道看懂题意了,但是也没能做出来. 1. Thickest Burger Time Limit: 2000/1000 MS (Java/Oth ...
- HDU 5950 Recursive sequence 【递推+矩阵快速幂】 (2016ACM/ICPC亚洲区沈阳站)
Recursive sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ...
- HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)
Counting Cliques Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- HDU 5948 Thickest Burger 【模拟】 (2016ACM/ICPC亚洲区沈阳站)
Thickest Burger Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- HDU 5949 Relative atomic mass 【模拟】 (2016ACM/ICPC亚洲区沈阳站)
Relative atomic mass Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- 2015ACM/ICPC亚洲区沈阳站 Pagodas
Pagodas Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
随机推荐
- Java基础系列(24)- 增强for循环
增强for循环 这里我们先只是见一面,做个了解,之后数组部分会重点使用 Java5引入了一种主要用于数组或集合的增强型for循环 Java增强for循环语法格式如下 for(声明语句:表达式){ // ...
- P4100-[HEOI2013]钙铁锌硒维生素【矩阵求逆,最大匹配】
正题 题目链接:https://www.luogu.com.cn/problem/P4100 题目大意 给出\(n\)个线性无关的向量\(A_i\),然后给出\(n\)个向量\(B_i\),求一个字典 ...
- 腾讯的表妹告诉我怎么学Python,今天就教我搭建Python环境和基本语法,我【码上开始】
本文首发公众号:码上开始 环境准备 Pycharm Python3 window10/win7 安装 Python 打开Python官网地址 下载 executable installer,x86 表 ...
- 深入浅出WPF-08.Event( 事件)01
事件(Event) 首先我们来继续说一下UI组件树,因为WPF事件 的路由环境就是组件树.WPF中的树有两种,一种是逻辑树(Logical Tree),一种是可视元素树(Visual Tree).逻辑 ...
- 1. JVM核心类加载器及类加载的全过程
运行环境: 下面说明一下我的运行环境.我是在mac上操作的. 先找到mac的java地址. 从~/.bash_profile中可以看到 java的home目录是: /Library/Java/Java ...
- C++ Primer 查漏补缺 —— C++ 中的各种初始化
初学者在刚开始读 C++ Primer 的时候,总是容易被书中各种初始化搞得头大:默认初始化.列表初始化.值初始化.类内初始值.构造函数初始值列表.new int 和 new int() 的区别... ...
- 解决Vite-React项目中js使用jsx语法报错的问题
背景 在做存量项目接入Vite测试时发现,存量(老)项目中很多是直接在js中书写jsx语法,使用Vite启动时就会抛出一堆问题Failed to parse source. 不嫌麻烦可以跑个脚本批量修 ...
- 看动画学算法之:平衡二叉搜索树AVL Tree
目录 简介 AVL的特性 AVL的构建 AVL的搜索 AVL的插入 AVL的删除 简介 平衡二叉搜索树是一种特殊的二叉搜索树.为什么会有平衡二叉搜索树呢? 考虑一下二叉搜索树的特殊情况,如果一个二叉搜 ...
- 架构师必备:MySQL主从延迟解决办法
上一篇文章介绍了MySQL主从同步的原理和应用,本文总结了MySQL主从延迟的原因和解决办法.如果主从延迟过大,会影响到业务,应当采用合适的解决方案. MySQL主从延迟的表现 先insert或upd ...
- python 类方法 静态方法
属性: 公有属性 (属于类,每个类一份) 普通属性 (属于对象,每个对象一份) 私有属性 (属于对象,跟普通属性相似,只是不能通过对象直接访问) 方法:(按作用) 构造方法 析构函数 方法: ...