【JS算法】回溯算法

题目:全排列
给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列
输入:nums = [1,2,3] //目标数组
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

用回溯算法解答,解题思路为:
1、递归函数,结束条件:临时数组(temp)长度==目标数组长度
2、临时数组(temp),往里加目标数组的元素,重复的不要
3、所以for循环,尝试向临时数组加入目标[0] 目标[1] 目标[2]
4、重要的是在递归返回后,从temp弹出一个元素;打印顺序为[1] [1,2] [1,2,3] [1,2][1] 这就是回溯
5、此时再次循环则是[1,3] [1,3,2] [1,3] [1] [ ]

举例1个简单的[1,2]

let cs = 0
let list = []
function test(temp, paramArr) {
  cs++
  if (temp.length === paramArr.length) {
    console.log(`递归第${cs}次-符合条件-结束`);
    cs--  //递归到头了,准备回去,所以cs--
    list.push([...temp])
    return
  }
  for (let i = 0; i < paramArr.length; i++) {
    if (temp.includes(paramArr[i])) {
      continue;
    }
    temp.push(paramArr[i])
    console.log(`递归第${cs}次的f${i}`, temp);
    test(temp, paramArr)
    temp.pop()
    console.log(`递归第${cs}次的f${i}-弹出后`, temp);
  }
  cs-- //本函数执行完毕,所以cs--
}

const paramArr = [1, 2]
test([], paramArr)
console.log("list:", list); //[ [ 1, 2 ], [ 2, 1 ] ]

递归第1次的f0 [ 1 ]
递归第2次的f1 [ 1, 2 ]
递归第3次-符合条件-结束
递归第2次的f1-弹出后 [ 1 ] //第二次调用函数未结束,所以接着走到函数底部
递归第1次的f0-弹出后 []
递归第1次的f1 [ 2 ] //执行第一次的for循环 i=1时
递归第2次的f0 [ 2, 1 ]
递归第3次-符合条件-结束
递归第2次的f0-弹出后 [ 2 ]
递归第1次的f1-弹出后 []


题目:单词搜索

给定一个 二维字符网格 board 和一个字符串单词 word
如果 word 存在于网格中,返回 true ;否则,返回 false
单词必须按照字母顺序,通过相邻的单元格内的字母构成
二维数组: board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]],
目标: word = "ABCCED"

解题思路:
1、双循环得出 行和列坐标,让每个坐标都做为开头 来尝试查找
2、找到第一个,然后上下左右接着找,为了避免又把第1个元素当结果,暂时用null代替
3、没找到则结束这个坐标的操作,把null也回溯恢复,然后开始下一个坐标的查找

var exist = function (board, word) { 
  //设置行列数
  let row = board.length;
  let col = board[0].length;

  //双循环,每个坐标都尝试 作目标的第1元素
  for (let i = 0; i < row; i++) {
    for (let j = 0; j < col; j++) {
      //从宫格图中第一个开始找(i,j),找目标第一个字母(word[0])
      const ret = find(i, j, 0); //返回true或false
      if (ret) {
        return ret;
      }
    }
  }
  return false; //结束了都没找到,就false

  //递归函数,第1个元素符合就接着内部再递归find上下左右找第2元素
  function find(r, c, cur) {
    if (r >= row || r < 0) return false;
    if (c >= col || c < 0) return false;
    if (board[r][c] !== word[cur]) return false; //不是目标元素则false

    //执行到这,说明rc坐标是目标元素;
    //先判断,如果是最后一个也找到了,返true结束
    if (cur == word.length - 1) return true;

    let letter = board[r][c]; //赋给临时变量
    board[r][c] = null; //用null替换做标记,避免下一个找上下左右时重复

    //进行下一步,上下左右查找
    //如:[0][0]是目标第1个元素,这里接着find找[0][1],[1][0]
    //没找到返回false,结束所有find,进入双for中的[0][1]
    const ret =
      find(r - 1, c, cur + 1) ||
      find(r + 1, c, cur + 1) ||
      find(r, c - 1, cur + 1) ||
      find(r, c + 1, cur + 1);
    //用null做标记是避免重复,但双for的find结束就需要恢复
    board[r][c] = letter;
    return ret;
  }
};

这里用回溯是避免重复,导致答案错误

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容

  • 我的解法都不靠近回溯思想😕单纯记录下这能有的解法,以后深入理解回溯回头看看🧐 一、组合[https://leetc...
    知向谁边阅读 163评论 0 0
  • Q19 回文解码 现在有一个字符串,你要对这个字符串进行 n 次操作,每次操作给出两个数字:(p, l) 表示当前...
    Giann阅读 605评论 0 0
  • 一、导论  对算法与数据结构掌握与理解不透彻,很难写出优秀简洁的代码。亡羊补牢为时不晚,所以工作后也时常拿起旧书本...
    ITsCLG阅读 919评论 2 5
  • 参考:十大经典排序算法 0、排序算法说明 0.1排序的定义 对一序列对象根据某个关键字进行排序。 0.2 术语说明...
    谁在烽烟彼岸阅读 1,013评论 0 12
  • 十大经典排序算法 十种常见排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时...
    seepDown阅读 297评论 0 0