逆向思维|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);

}

};

相关推荐
机器学习之心2 小时前
MATLAB灰狼优化算法(GWO)改进物理信息神经网络(PINN)光伏功率预测
神经网络·算法·matlab·物理信息神经网络
代码游侠2 小时前
学习笔记——ESP8266 WiFi模块
服务器·c语言·开发语言·数据结构·算法
倦王2 小时前
力扣日刷26110
算法·leetcode·职场和发展
涛涛北京2 小时前
【算法比较】
算法
yuniko-n2 小时前
【牛客面试 TOP 101】链表篇(二)
算法·链表·职场和发展
少许极端2 小时前
算法奇妙屋(二十三)-完全背包问题(动态规划)
java·算法·动态规划·完全背包
CoderCodingNo2 小时前
【GESP】C++五级练习(贪心思想考点) luogu-P1115 最大子段和
开发语言·c++·算法
Q741_1472 小时前
C++ 队列 宽度优先搜索 BFS 力扣 429. N 叉树的层序遍历 每日一题
c++·算法·leetcode·bfs·宽度优先
txinyu的博客2 小时前
make_shraed & make_unique 替代了new ? 什么场景使用new
开发语言·c++·算法