逆向思维|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 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码5 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发5 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre6 小时前
22 括号生成
算法·深度优先
努力也学不会java7 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎7 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan8 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业8 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe8 小时前
C++并发编程中的死锁避免
开发语言·c++·算法