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

}

};

相关推荐
NAGNIP3 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱11 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub14 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub14 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub14 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法