热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

每日一练(day03动态规划dp)

篇首语:本文由编程笔记#小编为大家整理,主要介绍了每日一练(day03--动态规划dp)相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了每日一练(day03--动态规划dp)相关的知识,希望对你有一定的参考价值。








文章目录


  • 前言
  • 题目
    • 求算术平方
    • 爬楼梯
    • 杨辉三角
    • 杨辉三角2
    • 不同路径




前言

最近两天被拉过去送新娘了,啥也没干。所以先来几道简单题找找自信(狗头)


题目

求算术平方



给你一个非负整数 x ,计算并返回 x 的 算术平方根 。


由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。


注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。


示例 1:


输入:x = 4 输出:2 示例 2:


输入:x = 8 输出:2 解释:8 的算术平方根是 2.82842…, 由于返回类型是整数,小数部分将被舍去


咋一看这个题目我就被吓到了,喵的不让用怎么算,想了半天我也不会别的方法呀,后来查了一下发现,喵的有种简化计算公式。
这个解法最简单。



e2lnx = x2


所以方法一就是直接套公式

class Solution
public int mySqrt(int x)
if (x == 0)
return 0;

int ans = (int) Math.exp(0.5 * Math.log(x));
return (long) (ans &#43; 1) * (ans &#43; 1) <&#61; x ? ans &#43; 1 : ans;


方法二就是二分法。就是猜测这个数字的范围。这个也很好理解上代码

class Solution
public int mySqrt(int x)
int left &#61; 0, right &#61; x, ans &#61; -1;
while (left <&#61; right)
int mid &#61; left &#43; (right - left) / 2;
if ((long) mid * mid <&#61; x)
ans &#61; mid;
left &#61; mid &#43; 1;
else
right &#61; mid - 1;


return ans;



爬楼梯

这个题目是一个经典的那个动态规划的题目&#xff0c;同时其实也是一个斐波那契数字的一个应用吧当初学python的时候我就记得那个书上老是喜欢那那个斐波那契数列和八皇后问题来玩&#xff0c;现在想想为什么当初没有从那个时候好好刷算法。

题目



假设你正在爬楼梯。需要 n 阶你才能到达楼顶。


每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f;


注意&#xff1a;给定 n 是一个正整数。


示例 1&#xff1a;


输入&#xff1a; 2 输出&#xff1a; 2 解释&#xff1a; 有两种方法可以爬到楼顶。
1 阶 &#43; 1 阶
2 阶 示例 2&#xff1a;


输入&#xff1a; 3 输出&#xff1a; 3 解释&#xff1a; 有三种方法可以爬到楼顶。
1 阶 &#43; 1 阶 &#43; 1 阶
1 阶 &#43; 2 阶
2 阶 &#43; 1 阶


思路其实很简单&#xff0c;你自己想想是吧&#xff0c;假设我要到第五个楼梯&#xff0c;那么我是不是可以直接从 第四个和第三个楼梯过来&#xff0c;那么到达第三个&#xff0c;第四个楼梯有几种方式&#xff0c;两个加起来就是第五个的过法&#xff0c;同时第三第四个又是从那里过来的&#xff0c;那么我们就可以得出结论&#xff0c;从 0 开始 0种走法&#xff0c; 到达第一个 有一种方式&#xff0c;第二个可以从第一个过来&#xff0c;也可以从第0个过来也就是 0 &#43; 1 &#xff0c;1种&#xff0c;以此类推

0 1 1 2 3 5 … 这不就是个数列么&#xff0c;这个数列几种写法这个题目几个解法。

我这里来个最简单的。

class Solution
public int climbStairs(int n)
int p &#61; 0, q &#61; 0, r &#61; 1;
for (int i &#61; 1; i <&#61; n; &#43;&#43;i)
p &#61; q;
q &#61; r;
r &#61; p &#43; q;

return r;


那么这里说一下的就是这个动态规划的题目有个典型的特征&#xff0c;那就是&#xff0c;我们可以得到一个状态方程&#xff0c;也就是说&#xff0c;那个当前这一步操作&#xff0c;一定是由上一步&#xff0c;或者上几部得到的&#xff0c;会受到前面的影响&#xff0c;也就是可以得到一个状态方程
F(n) &#61; F(n-m)&#43;F(n-k),m,k是步长&#xff0c;同时我们可以得到一开始的初始状态&#xff0c;也就是初始迭代状态

这种类型的题目和那个高中的那种什么等比数列的那种大题的思维方式很像。

既然说到了这个我们再来几道和动态规划有关的题目吧。


杨辉三角


先说一下特点&#xff0c;仔细看最外层都是 1 &#xff0c;第一第二层都是 1 也就是初始状态
中间的数字收到上面两个的影响&#xff0c;可以构建方程&#xff0c;所以没跑的动态规划&#xff0c;并且我们知道了状态方程和初始状态&#xff0c;那么接下来想要求取第几层的那个还不简单吗。



输入: numRows &#61; 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]


这里我们用到二维数组去存&#xff0c;然后就行了。java版本的有点难看&#xff0c;这里给出 java 和 python 版本

class Solution
public List<List<Integer>> generate(int numRows)
List<List<Integer>> YanghuiSanJiao &#61; new ArrayList<List<Integer>>();
for (int i &#61; 0; i < numRows; i&#43;&#43;)
List<Integer> row &#61; new ArrayList<Integer>();
for (int j &#61; 0; j <&#61; i; &#43;&#43;j)
if (j &#61;&#61; 0 || j &#61;&#61; i)
row.add(1);
else
row.add(YanghuiSanJiao.get(i - 1).get(j - 1) &#43; YanghuiSanJiao.get(i - 1).get(j));


YanghuiSanJiao.add(row);

return YanghuiSanJiao;


python

class Solution:
def generate(self, numRows: int) -> List[List[int]]:
YanghuiSanJiao &#61; list()
for i in range(numRows):
row &#61; list()
for j in range(0, i &#43; 1):
if j &#61;&#61; 0 or j &#61;&#61; i:
row.append(1)
else:
row.append(YanghuiSanJiao[i - 1][j] &#43; YanghuiSanJiao[i - 1][j - 1])
YanghuiSanJiao.append(row)
return YanghuiSanJiao

杨辉三角2

这个就是小变形嘛



给定一个非负索引 rowIndex&#xff0c;返回「杨辉三角」的第 rowIndex 行。


在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。


示例 1:


输入: rowIndex &#61; 3 输出: [1,3,3,1]


class Solution
public List<Integer> getRow(int rowIndex)
List<List<Integer>> YanghuiSanJiao &#61; new ArrayList<List<Integer>>();
for (int i &#61; 0; i <&#61; rowIndex; &#43;&#43;i)
List<Integer> row &#61; new ArrayList<Integer>();
for (int j &#61; 0; j <&#61; i; &#43;&#43;j)
if (j &#61;&#61; 0 || j &#61;&#61; i)
row.add(1);
else
row.add(YanghuiSanJiao.get(i - 1).get(j - 1) &#43; YanghuiSanJiao.get(i - 1).get(j));


YanghuiSanJiao.add(row);

return YanghuiSanJiao.get(rowIndex);



不同路径



一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。


机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。


问总共有多少条不同的路径&#xff1f;
输入&#xff1a;m &#61; 3, n &#61; 7
输出&#xff1a;28
示例 2&#xff1a;


输入&#xff1a;m &#61; 3, n &#61; 2 输出&#xff1a;3


这个也是一样的。

直接给代码了。

class Solution
public int uniquePaths(int m, int n)
int[][] f &#61; new int[m][n];
for (int i &#61; 0; i < m; &#43;&#43;i)
f[i][0] &#61; 1;

for (int j &#61; 0; j < n; &#43;&#43;j)
f[0][j] &#61; 1;

for (int i &#61; 1; i < m; &#43;&#43;i)
for (int j &#61; 1; j < n; &#43;&#43;j)
f[i][j] &#61; f[i - 1][j] &#43; f[i][j - 1];


return f[m - 1][n - 1];


玩到这里比较简单的动态规划基本就这样了。







推荐阅读
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 开发笔记:2020 BJDCTF Re encode
    开发笔记:2020 BJDCTF Re encode ... [详细]
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • #点球小游戏fromrandomimportchoiceimporttimescore[0,0]direction[left,center,right]defkick() ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • 本文详细介绍了Python中的可迭代对象、迭代器和生成器的概念及实现方式。通过实例代码展示如何创建和使用这些对象,帮助读者更好地理解和掌握其原理。 ... [详细]
  • 在本教程中,我们将深入探讨如何使用 Python 构建游戏的主程序模块。通过逐步实现各个关键组件,最终完成一个功能完善的游戏界面。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
author-avatar
xiubao
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有