hihocoder 1584 Bounce (数学 && 规律) ACM-ICPC北京赛区2017网络赛
题意:
给定一副n*m的格子图, 问从左上角的点开始往右下角滑,碰到墙壁就反弹, 碰到角落就停止, 问恰好经过一次的格子有多少个。

如图,恰好经过一次的格子有39个。
分析:
首先要引入两个概念, “路径长”,“格子数”。
路径长指的是整段路程的长度,如果走过同一个格子两次那么就算是2步。
格子数指的是整段路程经过的格子。
如果一个图是9*9(形如n*n)的, 那么就是从左上角一直到右下角, 走过的“路径长”恰好等于“格子数”,没有任何的格子被走过两次。

但对于一幅9 * 15这样不规则的图,“格子数”为“48”,“路径长”为57。
如果把格子都平移成一条直线的话, 那么有一些格子就会存在“共用”。上图中1~9号都成为“共用点”,其中“3、6、9”为行共用,“2、4、5、7、8、10”为列共用点,1和11分别给起点和终点。
只考虑1 - 2 - 3 - 4 - 5 - 6 这条连线, 如果把他们平移成行的话, 那么只有15 + 14的“路径长” , 并非两行15*2 =30 “路径长”。 因为3号顶点是这两行共用的, 不能单独算。整幅图而言,因为行共用点有3个, 所以最后如果都算行平移的话会有15 + (15-1)*3 = 57“路径长”, 如果都算列平移同样会有9 + (9-1)*6 = 57“路径长”。

那么我们考虑将一个n*m的“路径长”,放大成最小倍数使其变为没有“共用点”的 a*a图便于我们运算。 那么a应该等于 (lcm(n-1,m-1)), 行放大倍数为a/n, 列放大倍数为a/m。
注意最后再加上1,因为“共用点总比边数少1”,换而言之就是有一条边是没有公共点的, 我们都按“lcm(n-1,m-1)”倍数去放大的话就会少算了一格。
这样我们就能得出“路径长”的公式为 lcm(n-1,m-1) + 1。

考虑2*3的格子, 现在行公用点其实是0, 格子共有3*1 = 3 个, 竖公共点有1个, 格子共有2+(2-1)*1 = 3 个。

接下来我们处理,“路径长” 和“格子数”的关系。
由图可得, 因为有些格子走了2次(至多2次),所以"路径长”算多了一次。
其实 “路径长” =“走过一次格子数” * 1 + “走过两次格子数” * 2。
那么我们既然要求的是“走过一次的格子数”, 而且“路径长“也算出来了, 就可以得出。
"路径长" - “走过两次格子数”*2 = “走过一次格子数” (即都视为走过两次的, 减掉路径就知道走过一次格子有多少)。
所以问题就转化为求“格子数”的问题了,
而且发现没有, 9 * 15的图中,按行算只有 4 , 按列算只有7, 恰好是 lcm(8,14) = 56
56/ 8 = 7和 56 / 14 = 4 的结果。
这就说明, 我们用“共用点”计算的行列,是和我们放大的倍数有关系的。
那些走过两次的点, 其实就是行列的交叉点, 推了一下大概的公式,大概就是

#include<bits/stdc++.h>
using namespace std;
long long gcd(long long a, long long b){
return b == ? a : gcd(b,a%b);
}
long long lcm(long long a, long long b){
return a*b/gcd(a,b);
}
int main(){
long long n , m;
while(~scanf("%lld %lld", &n, &m)){
long long l = lcm(n-,m-);
long long a = l/(m-) , b = l/(n-);
printf("%lld\n",l - a*b + a + b);
}
return ;
}
hihocoder 1584 Bounce (数学 && 规律) ACM-ICPC北京赛区2017网络赛的更多相关文章
- hihocoder 1586 ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛-题目9 : Minimum【线段树】
https://hihocoder.com/problemset/problem/1586 线段树操作,原来题并不难..... 当时忽略了一个重要问题,就是ax*ay要最小时,x.y可以相等,那就简单 ...
- 【分类讨论】【计算几何】【凸包】hihocoder 1582 ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛 E. Territorial Dispute
题意:平面上n个点,问你是否存在一种黑白染色方案,使得对于该方案,无法使用一条直线使得黑色点划分在直线一侧,白色点划分在另一侧.如果存在,输出一种方案. 如果n<=2,显然不存在. 如果所有点共 ...
- 【线段树】hihocoder 1586 ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛 I. Minimum
题意:给你一个序列(长度不超过2^17),支持两种操作:单点修改:询问区间中最小的ai*aj是多少(i可以等于j). 只需要线段树维护区间最小值和最大值,如果最小值大于等于0,那答案就是minv*mi ...
- 【最短路】【Heap-dijkstra】hihocoder 1587 ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛 J. Typist's Problem
题意:给你一个串,仅含有a~g,且每个字母只出现最多一次.和一个光标初始位置,以及一个目标串,问你最少要多少的代价变化成目标串. 有五种操作:在光标前添加一个未出现过的字母,代价1. 删除光标前或者光 ...
- hihoCoder 1584 Bounce 【数学规律】 (ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛)
#1584 : Bounce 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 For Argo, it is very interesting watching a cir ...
- hihoCoder 1578 Visiting Peking University 【贪心】 (ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛)
#1578 : Visiting Peking University 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 Ming is going to travel for ...
- hihoCoder 1582 Territorial Dispute 【凸包】(ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛)
#1582 : Territorial Dispute 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 In 2333, the C++ Empire and the Ja ...
- hihoCoder 1586 Minimum 【线段树】 (ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛)
#1586 : Minimum 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 You are given a list of integers a0, a1, …, a2 ...
- hihoCoder 1631 Cats and Fish(ACM-ICPC北京赛区2017网络同步赛)
时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 There are many homeless cats in PKU campus. They are all happy ...
随机推荐
- 接口测试postman和Jmeter
接口测试属于功能测试的范畴,一般来说分为两种,一种是程序内部的接口,一种是系统对外的接口. postman测试接口 1. get请求: (1) 直接在浏览器中输入接口地址+?+参数 (2)使用post ...
- ssh密钥的分发之一:ssh-copy-id
ssh密钥的分发 我们在使用客户端账号对主机记性管理的时候,可以分为以下两种情况: .第一种情况,直接使用root账号: 优点:使用root账号密钥分发简单,指令执行简单 缺点:不安全 .第二种情况, ...
- javascript简单的表单验证
<html> <head> <title>用户登录</title> <script language="javascript" ...
- 491 Increasing Subsequences 递增子序列
给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2.示例:输入: [4, 6, 7, 7]输出: [[4, 6], [4, 7], [4, 6, 7], [4, 6, ...
- hdu 2604 Queuing dp找规律 然后矩阵快速幂。坑!!
http://acm.hdu.edu.cn/showproblem.php?pid=2604 这题居然O(9 * L)的dp过不了,TLE, 更重要的是找出规律后,O(n)递推也过不了,TLE,一定 ...
- .net 音频转换 .amr 转 .mp3 (七牛转换法)
.amr 用于移动设备的音频,压缩比比较大,多用于人声.通话,效果还行!所以,移动设备多采用amr格式来进行录存!比较常见的例子:通话录音,微信语音以及录音等! 这个鬼,用两个字来形容,就是“蛋疼”: ...
- 【前端】jq弹出一个透明小提示窗,然后逐渐消失
function show_main(content) { var showWindow = '<div id="show_main" style="borde ...
- 外文翻译 《How we decide》被情感愚弄 第二节
本节阅读感言:我们在遭受损失后,很容易破罐子破摔,做出更糟糕的决定. 书的导言 本章第一节 情感系统的缺陷会产生很重要的影响.想一想股票市场,一个典型的随机系统的例子.短期的波动无法给未来长期的股市情 ...
- Ubuntu16下查看CPU、内存和磁盘相关信息
1.内存 查看内存#free -m total used free shared buff/cache available Mem: Swap: 2.CPU 查看逻辑cpu个数: #cat /proc ...
- Synplify FPGA 逻辑综合
作为 Synopsys FPGA 设计解决方案的一部分,Synplify FPGA 综合软件是实现高性能.高性价比的 FPGA 设计的行业标准. 其独特的行为提取综合技术 (Behavior Extr ...