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


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







推荐阅读
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文探讨了C语言中指针的应用与价值,指针在C语言中具有灵活性和可变性,通过指针可以操作系统内存和控制外部I/O端口。文章介绍了指针变量和指针的指向变量的含义和用法,以及判断变量数据类型和指向变量或成员变量的类型的方法。还讨论了指针访问数组元素和下标法数组元素的等价关系,以及指针作为函数参数可以改变主调函数变量的值的特点。此外,文章还提到了指针在动态存储分配、链表创建和相关操作中的应用,以及类成员指针与外部变量的区分方法。通过本文的阐述,读者可以更好地理解和应用C语言中的指针。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文详细解析了JavaScript中相称性推断的知识点,包括严厉相称和宽松相称的区别,以及范例转换的规则。针对不同类型的范例值,如差别范例值、统一类的原始范例值和统一类的复合范例值,都给出了具体的比较方法。对于宽松相称的情况,也解释了原始范例值和对象之间的比较规则。通过本文的学习,读者可以更好地理解JavaScript中相称性推断的概念和应用。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
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社区 版权所有