逆向思维|memo

正着不行就倒着,wa一次人之常情

lc3609

记忆化DFS从目标坐标反向递归,根据横竖坐标大小关系尝试减法或折半操作

统计从目标回到起始坐标的最少操作次数,无法到达则返回-1

class Solution {

public:

map<pair<int,int>,int> mp;

int dfs(int r,int c,int& tx,int& ty){

if(r < tx || c < ty) return -1;

if(r==tx && c==ty){

return 0;

}

int mi = 10000;

if(r >= c){

int d = r - c;

int p1 = -1,p2 = -1;

if(d <= c){

p1 = dfs(r-c,c,tx,ty);

}

int p = (r%2==0 ? r/2:-100);

if(p >= c){

p2 = dfs(r/2,c,tx,ty);

}

if(p1!=-1) mi = p1;

if(p2!=-1) mi=min(mi,p2);

}

if(c >= r){

int d = c - r;

int p1 = -1,p2 = -1;

if(d <= r){

p1 = dfs(r,c - r,tx,ty);

}

int p = (c%2==0 ? c/2:-100);

if(p >= r){

p2 = dfs(r,c/2,tx,ty);

}

if(p1!=-1) mi = min(mi,p1);

if(p2!=-1) mi=min(mi,p2);

}

if(mi == 10000) return -1;

return mi + 1;

}

int minMoves(int sx, int sy, int tx, int ty) {

if(sx==0&&sy==0){

if(tx==0&&ty==0) return 0;

return -1;

}

return dfs(tx,ty,sx,sy);

}

};

相关推荐
-dzk-36 分钟前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅1 小时前
hot100 78.子集
java·算法
Jasmine_llq1 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪1 小时前
快速进制转换
笔记·算法
m0_706653231 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你912 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233902 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder1232 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_715575342 小时前
分布式任务调度系统
开发语言·c++·算法