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


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







推荐阅读
  • 本文介绍了使用Python和C语言编写程序来计算一个给定数值的平方根的方法。通过迭代算法,我们能够精确地得到所需的结果。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • 本文探讨了在已知最终数组尺寸不会超过5000x10的情况下,如何利用预分配和调整大小的方法来优化Numpy数组的创建过程,以提高性能并减少内存消耗。 ... [详细]
  • 一、使用Microsoft.Office.Interop.Excel.DLL需要安装Office代码如下:2publicstaticboolExportExcel(S ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • Python网络编程:深入探讨TCP粘包问题及解决方案
    本文详细探讨了TCP协议下的粘包现象及其产生的原因,并提供了通过自定义报头解决粘包问题的具体实现方案。同时,对比了TCP与UDP协议在数据传输上的不同特性。 ... [详细]
  • 本文介绍了如何使用 Python 的 Pyglet 库加载并显示图像。Pyglet 是一个用于开发图形用户界面应用的强大工具,特别适用于游戏和多媒体项目。 ... [详细]
  • 深入理解iOS中的链式编程:以Masonry为例
    本文通过介绍Masonry这一轻量级布局框架,探讨链式编程在iOS开发中的应用。Masonry不仅简化了Auto Layout的使用,还提高了代码的可读性和维护性。 ... [详细]
  • 解析Java虚拟机HotSpot中的GC算法实现
    本文探讨了Java虚拟机(JVM)中HotSpot实现的垃圾回收(GC)算法,重点介绍了根节点枚举、安全点及安全区域的概念和技术细节,以及这些机制如何影响GC的效率和准确性。 ... [详细]
  • Hanks博士是一位著名的生物技术专家,他的儿子Hankson对数学有着浓厚的兴趣。最近,Hankson遇到了一个有趣的数学问题,涉及求解特定条件下的正整数x,而不使用传统的辗转相除法。 ... [详细]
  • 网络流24题——试题库问题
    题目描述:假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算 ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
  • 本文由chszs撰写,详细介绍了Apache Mina框架的核心开发流程及自定义协议处理方法。文章涵盖从创建IoService实例到协议编解码的具体步骤,适合希望深入了解Mina框架应用的开发者。 ... [详细]
  • Canopy环境安装与使用指南
    《利用Python进行数据分析》一书推荐使用EPDFree版本的环境,然而随着技术的发展,目前更多人倾向于使用Canopy。本文将详细介绍Canopy的安装及使用方法。 ... [详细]
  • 本文分享了作者在使用LaTeX过程中的几点心得,涵盖了从文档编辑、代码高亮、图形绘制到3D模型展示等多个方面的内容。适合希望深入了解LaTeX高级功能的用户。 ... [详细]
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社区 版权所有