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

Posted zinn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CF 1036 B Diagonal Walking v.2 —— 思路相关的知识,希望对你有一定的参考价值。

题目: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 —— 思路的主要内容,如果未能解决你的问题,请参考以下文章

Codeforces 1036B Diagonal Walking v.2 贪心

Diagonal Walking v.2 CodeForces - 1036B (思维,贪心)

codeforces cf edu round#50 B. Diagonal Walking v.2

[CF1036C]Classy Numbers

Codeforces | CF1028C Rectangles

B1036. 跟奥巴马一起编程