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

}

};

相关推荐
2301_8227032014 分钟前
鸿蒙flutter三方库实战——教育与学习平台:Flutter Markdown
学习·算法·flutter·华为·harmonyos·鸿蒙
Jia ming24 分钟前
C语言实现日期天数计算
c语言·开发语言·算法
无限进步_1 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
苏纪云1 小时前
蓝桥杯考前突击
c++·算法·蓝桥杯
W23035765731 小时前
经典算法详解:最长公共子序列 (LCS) —— 从暴力递归到动态规划完整实现
算法·动态规划·最长子序列
pzx_0011 小时前
【优化器】 随机梯度下降 SGD 详解
人工智能·python·算法
小肝一下2 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
无限进步_2 小时前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
Meme Buoy2 小时前
18.补充数学1:生成树-最短路径-最大流量-线性规划
数据结构·算法
paeamecium2 小时前
【PAT甲级真题】- Count PAT‘s (25)
c++·算法·动态规划·pat考试·pat