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

✌粤嵌—2024/3/11—跳跃游戏

代码实现:

方法一:递归+记忆化

int path;
int used[10000];bool dfs(int *nums, int numsSize) {if (path == numsSize - 1) {return true;}for (int i = 1; i <= nums[path]; i++) {if (used[path + i]) {continue;}path += i;used[path] = 1;if (dfs(nums, numsSize)) {return true;}path -= i;}return false;
}bool canJump(int *nums, int numsSize) {path = 0;memset(used, 0, sizeof(int) * numsSize);return dfs(nums, numsSize);
}

方法二:动态规划

bool canJump(int *nums, int numsSize) {bool dp[numsSize]; // 能否到达dp[i]memset(dp, false, sizeof(dp));dp[0] = true;for (int i = 1; i < numsSize; i++) {for (int j = 0; j < i; j++) {if (dp[j] && nums[j] + j >= i) {dp[i] = true;break;}}}return dp[numsSize - 1];
}

方法三:贪心

每次取最大跳跃步数(取最大覆盖范围)

bool canJump(int *nums, int numsSize) {if (numsSize == 1) {return true;}int cover = 0;for (int i = 0; i <= cover; i++) {cover = cover > i + nums[i] ? cover : i + nums[i];if (cover >= numsSize - 1) {return true;}}return false;
}
http://www.lryc.cn/news/340690.html

相关文章:

  • Docker入门实战教程
  • 数据结构初阶:二叉树(一)
  • 基于逻辑回归和支持向量机的前馈网络进行乳腺癌组织病理学图像分类
  • 35-4 fastjson漏洞复现
  • Qt-控件篇
  • 实现 Table 的增加和删除,不依赖后端数据回显
  • 个人网站开发记录(七)——三系统后端nodejs+express
  • C#入门理解设计模式的6大原则
  • Linux如何切换root用户
  • uniapp小程序编译报错
  • van-uploader 在app内嵌的webview中的一些坑
  • 使用Kotlin进行全栈开发 Ktor+Kotlin/JS
  • 数据结构_带头双向循环链表
  • 常见的垃圾回收器(下)
  • 网桥的原理
  • STM32 CAN过滤器细节
  • 网络编程(现在不重要)
  • 10-菜刀连接木马
  • Unity数据持久化—Json存档
  • 基于SSM的在线学习系统的设计与实现(论文+源码)_kaic
  • 数据库SQL语言实战(二)
  • idea错误地commit后如何处理
  • VRTK(Virtual Reality Toolkit)深入介绍
  • 【LeetCode热题100】【贪心算法】划分字母区间
  • 第二届数据安全大赛暨首届“数信杯”数据安全大赛数据安全积分争夺赛-东区预赛部分WP
  • 如何在Python中使用matplotlib库进行数据可视化?
  • 网工基础协议——TCP/UDP协议
  • ClickHouse--16--普通函数
  • 03-JAVA设计模式-组合模式
  • C++发票识别、发票查验接口示例,您的“发票管理专家”