热门标签 | 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];


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







推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 学习SLAM的女生,很酷
    本文介绍了学习SLAM的女生的故事,她们选择SLAM作为研究方向,面临各种学习挑战,但坚持不懈,最终获得成功。文章鼓励未来想走科研道路的女生勇敢追求自己的梦想,同时提到了一位正在英国攻读硕士学位的女生与SLAM结缘的经历。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了多因子选股模型在实际中的构建步骤,包括风险源分析、因子筛选和体系构建,并进行了模拟实证回测。在风险源分析中,从宏观、行业、公司和特殊因素四个角度分析了影响资产价格的因素。具体包括宏观经济运行和宏经济政策对证券市场的影响,以及行业类型、行业生命周期和行业政策对股票价格的影响。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
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社区 版权所有