码迷,mamicode.com
首页 > 其他好文 > 详细

CF 1036 B Diagonal Walking v.2 —— 思路

时间:2018-09-08 11:53:15      阅读:407      评论:0      收藏:0      [点我收藏+]

标签:http   code   思路   奇数   force   方向   通过   contest   def   

题目:http://codeforces.com/contest/1036/problem/B

题意:从 (0,0) 走到 (n,m),每一步可以向八个方向走一格,问恰好走 k 步能否到达,能到达则输出最多能走多少斜步;

自己想得太复杂了...

首先,判断 -1 就看横纵距离中的较大值是否大于 k ,因为最少走 max(n,m) 步可以到达;

设 m > n;

如果 m - n 为奇数,那么显然会有一步必须直着走,那么 k --;

这里可以通过走法来调节剩余步数的奇偶,就是直着走过去或者拐一下走过去的区别,所以到达后不会再有 k 的损失;

如果 m - n 为偶数,首先可以全部斜着走过去;

到达以后的剩余步数如果是偶数,那么来回进出终点,不会有斜着走的损失;

如果是奇数,则会损失两步,会有两个直着走的步来代替一个斜着走;

这题就做完了-_-

CF 1036 B Diagonal Walking v.2 —— 思路

标签:http   code   思路   奇数   force   方向   通过   contest   def   

原文地址:https://www.cnblogs.com/Zinn/p/9607987.html

(1)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!