当前位置: 首页 > news >正文

力扣动态规划-17【算法学习day.111】

前言

###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.统计异或值为给定值的路径数目

题面链接:3393. 统计异或值为给定值的路径数目 - 力扣(LeetCode)

题面:

附上灵神代码:

class Solution {private static final int MOD = 1_000_000_007;public int countPathsWithXorValue(int[][] grid, int k) {int mx = 0;for (int[] row : grid) {for (int val : row) {mx = Math.max(mx, val);}}int u = 1 << (32 - Integer.numberOfLeadingZeros(mx));if (k >= u) {return 0;}int m = grid.length;int n = grid[0].length;int[][][] memo = new int[m][n][u];for (int[][] mat : memo) {for (int[] row : mat) {Arrays.fill(row, -1);}}return dfs(grid, m - 1, n - 1, k, memo);}private int dfs(int[][] grid, int i, int j, int x, int[][][] memo) {if (i < 0 || j < 0) {return 0;}int val = grid[i][j];if (i == 0 && j == 0) {return x == val ? 1 : 0;}if (memo[i][j][x] != -1) {return memo[i][j][x];}int left = dfs(grid, i, j - 1, x ^ val, memo);int up = dfs(grid, i - 1, j, x ^ val, memo);return memo[i][j][x] = (left + up) % MOD;}
}

后言

上面是动态规划相关的习题,共勉

 

 

http://www.lryc.cn/news/529956.html

相关文章:

  • 读书笔记-《你的灯亮着吗?》
  • MATLAB实现多种群遗传算法
  • tf.Keras (tf-1.15)使用记录3-model.compile方法
  • Prometheus 中的 Exporter
  • 网工_HDLC协议
  • leetcode 2563. 统计公平数对的数目
  • Debian 10 中 Linux 4.19 内核在 x86_64 架构上对中断嵌套的支持情况
  • FLTK - FLTK1.4.1 - demo - bitmap
  • 数据结构 树1
  • android主题设置为..DarkActionBar.Bridge时自定义DatePicker选中日期颜色
  • MySQL 如何深度分页问题
  • 1.攻防世界easyphp
  • 深度学习 Pytorch 神经网络的学习
  • 如何利用天赋实现最大化的价值输出-补
  • Vue简介
  • three.js+WebGL踩坑经验合集(6.2):负缩放,负定矩阵和行列式的关系(3D版本)
  • 使用 OpenResty 构建高效的动态图片水印代理服务20250127
  • Kafka下载
  • 【C++语言】卡码网语言基础课系列----5. A+B问题VIII
  • IP服务模型
  • 仿真设计|基于51单片机的温湿度、一氧化碳、甲醛检测报警系统
  • QModbusTCPClient 服务器断开引起的程序崩溃
  • Vue 3 30天精进之旅:Day 11 - 状态管理
  • npm 和 pip 安装中常见问题总结
  • Flutter开发环境配置
  • Two Divisors ( Educational Codeforces Round 89 (Rated for Div. 2) )
  • 亚博microros小车-原生ubuntu支持系列:17 gmapping
  • Java面试题2025-并发编程进阶(线程池和并发容器类)
  • Stable Diffusion 3.5 介绍
  • 云计算部署模式全面解析