题解 | #24点游戏算法#

24点游戏算法

http://www.nowcoder.com/practice/fbc417f314f745b1978fc751a54ac8cb

function calcGame(line) {
  let sign = false;
  const dp = (arr, res) => {
    //剪枝
    if (res > 24) {
      return;
    }
    //满足条件并剪枝
    if (res === 24) {
      sign = true;
      return;
    }
    if (res < 24) {
      for (let i = 0; i < arr.length; i++) {
        //拷贝下数组,原数组需要多次使用,不能修改
        let newArr = arr.slice();
        //下一次是数组是去掉当前数字的数组
        newArr.splice(i,1);
        if(res===0) {
          //初始化的时候
          dp(newArr, arr[i]);
        }else{
          //正常+-*/
          dp(newArr, res * arr[i]);
          dp(newArr, res + arr[i]);
          dp(newArr, res - arr[i]);
          dp(newArr, res / arr[i]);
        }
      }
    }
  };
  dp(line, 0);
  console.log(sign);
}
全部评论
思路是正解且很牛掰,但是运算得不到答案,因为我发现漏掉了一部分(题意“对顺序无要求”)致使得不到24的结果,我的改法是在你的基础上增加了顺序调换:dp(newArr, res * arr[i]);dp(newArr, res + arr[i]);dp(newArr, res - arr[i]);dp(newArr, res / arr[i]);dp(newArr, arr[i]*res);dp(newArr, arr[i]+res);dp(newArr, arr[i]-res);dp(newArr, arr[i]/res);
1 回复 分享
发布于 2022-03-04 16:36
这里将res > 24剪枝了的依据是什么,后续不是还有- / 操作吗。
点赞 回复 分享
发布于 2022-11-22 16:38 湖南

相关推荐

不愿透露姓名的神秘牛友
07-07 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
码农索隆:想看offer细节
点赞 评论 收藏
分享
评论
8
3
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务