LeetCode—<动态规划专项>剑指 Offer 19、49、60

剑指 Offer 19. 正则表达式匹配、49. 丑数、60. n个骰子的点数

题目描述:
[19]
请实现一个函数用来匹配包含’. ‘和’‘的正则表达式。模式中的字符’.‘表示任意一个字符,而’'表示它前面的字符可以出现任意次(含0次)。在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"abaca"匹配,但与"aa.a"和"ab*a"均不匹配。
[49]
我们把只包含质因子 2、3 和 5 的数称作丑数(Ugly Number)。求按从小到大的顺序的第 n 个丑数。
[60]
把n个骰子扔在地上,所有骰子朝上一面的点数之和为s。输入n,打印出s的所有可能的值出现的概率。

你需要用一个浮点数数组返回答案,其中第 i 个元素代表这 n 个骰子所能掷出的点数集合中第 i 小的那个的概率。

考察重点
第19题二维状态数组,其中dp[i][j]=true表示s[0, i)与p[0, j)模式匹配
第49题三个指针分别指向2,3,5对应的位置,每次放入积最小的数
第60题令f(n,s)为二维矩阵,表示为n个骰子点数为s的情况;有f(n,s)=f(n-1,s-1)+f(n-1,s-2)+f(n-1,s-3)+f(n-1,s-4)+f(n-1,s-5)+f(n-1,s-6)

第19题

func isMatch(s string, p string) bool {sLen, pLen := len(s), len(p)var dp [][]boolfor x := 0; x <= sLen; x++ {		//建立一个存储状态的数组ar := make([]bool, pLen+1)		//其中dp[i][j]=true表示s[0, i)与p[0, j)模式匹配dp = append(dp, ar)}dp[0][0] = true //边界条件, 如果从0开始则边界为-1,因此我们将结果存放在1——(Len+1),所以要注意dp比s和p多一位for i := 0; i <= sLen; i++ {for j := 1; j <= pLen; j++ {if p[j-1] == '*' {		//dp[i][j-2]表示'*'代表的次数为0,后面表示'*'代表的次数为1dp[i][j] = dp[i][j-2] || (i > 0 && (s[i-1] == p[j-2] || p[j-2] == '.') && dp[i-1][j])} else {dp[i][j] = i > 0 && (s[i-1] == p[j-1] || p[j-1] == '.') && dp[i-1][j-1]}}}return dp[sLen][pLen]
}

第49题

func nthUglyNumber(n int) int {res := make([]int, n)res[0] = 1p2, p3, p5 := 0, 0, 0for i := 1;i < n;i ++{res[i] = min(res[p2] * 2, res[p3] * 3, res[p5] * 5)if res[i] == res[p2] * 2{   //不可以使用if else,当多个最小值相等时,应该同时后移以保障去重p2 ++}if res[i] == res[p3] * 3{p3 ++}if res[i] == res[p5] * 5{p5 ++}}return res[n-1]
}func min(a, b, c int)int{if(a < b){if a < c{return a}return c}if b < c{return b}return c
}

第60题

// 令f(n,s)为二维矩阵,表示为n个骰子点数为s的情况
func dicesProbability(n int) []float64 {dp := make([][]int32, 0)        //建立一个n+1行,n*6+1列的数组。其中+1是方便处理边界。for i := 0;i < n+1;i ++{tt := make([]int32, n*6+1)dp = append(dp, tt)}res := make([]float64, 5*n+1)   //保存n个骰子时的结果allSituation := math.Pow(6, float64(n))     // 数组中保存的出现的次数,所以计算总次数以计算概率for j := 1; j <= 6; j++ {dp[1][j] = 1}for i := 1; i <= n; i++ {       // i个骰子for j := i; j <= n*6; j++ {     //和为jfor k := 1; k <= 6; k++ {      // f(n,s)=f(n-1,s-1)+f(n-1,s-2)+f(n-1,s-3)+f(n-1,s-4)+f(n-1,s-5)+f(n-1,s-6)if j >= k {dp[i][j] += dp[i-1][j-k]}if i == n {res[j-i] = float64(dp[i][j]) / allSituation}}}}return res
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/263170.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java并发编程-Executor框架

http://www.iteye.com/topic/366591 一、创建线程池 Executors类&#xff0c;提供了一系列工厂方法用于创先线程池&#xff0c;返回的线程池都实现了ExecutorService接口。 public static ExecutorService newFixedThreadPool(int nThreads) 创建固定数目线程的线程池。 public…

我,只关心接口

我们去饭店吃饭&#xff0c;坐下。然后叫&#xff1a;服务员&#xff01;好&#xff0c;服务员来了。你会说&#xff1a;倒茶。或说&#xff1a;点菜。是吧。你不会说&#xff1a;来&#xff0c;我们讨论一下什么是面向对象吧。这是为什么呢&#xff1f;很简单&#xff0c;对你…

java实现颜色Color对象和16进制之间的转换

package com.tsxs.test;import java.awt.Color;public class TestColor {public static void main(String[] args) {System.out.println(toHexFromColor(Color.BLUE));System.out.println(toColorFromString(toHexFromColor(Color.BLUE)));}/*** Color对象转换成字符串* param …

POJ 2054 Color a Tree (贪心)

$ POJ~2054~Color~a~Tree $ $ solution: $ 我们先从题中抽取信息&#xff0c;因为每个点的费用和染色的次数有关&#xff0c;所以我们可以很自然的想到先给权值大的节点染色。但是题目还说每个节点染色前它的父亲节点也必须被染色&#xff0c;这就有了很多的后效性。 暂时没有办…

LeetCode—剑指 Offer 51. 数组中的逆序对

剑指 Offer 51. 数组中的逆序对 题目描述&#xff1a; [51] 在数组中的两个数字&#xff0c;如果前面一个数字大于后面的数字&#xff0c;则这两个数字组成一个逆序对。输入一个数组&#xff0c;求出这个数组中的逆序对的总数。 考察重点&#xff1a; 第51题归并排序实现。在…

Callable与Future的介绍

Callable与Future的介绍Callable与 Future 两功能是Java在后续版本中为了适应多并法才加入的&#xff0c;Callable是类似于Runnable的接口&#xff0c;实现Callable接口的类和实现Runnable的类都是可被其他线程执行的任务。 Callable的接口定义如下&#xff1b; public interfa…

使用Null Object设计模式[转]

在ESFramework的设计实现中&#xff0c;很多地方都用到了Null Object设计模式。Null Object模式的含义在于&#xff0c;提供一个对象给指定的类型&#xff0c;用以代替这个对象为空的情况。 Null Object提供了“什么也不做”的行为,隐藏来自它的合作者的细节。对于如何理解和应…

angular input使用输入框filter格式化日期

最近使用angular日期选取器。只需要把所选的输出迄今input输入框&#xff0c;根据默认的假设&#xff0c;显示是在时间的形式的时间戳。不符合规定。需要格成一个特定的公式格公式。但input上ng-model不能直接对用于filter。因此内容需要一种方法来在这里显示格式化。 网上寻找…

CH0805 防线 (二分值域,前缀和,特殊性质)

$ CH~0805~ $ 防线 (二分值域&#xff0c;前缀和&#xff0c;特殊性质) $ solution: $ 注意博主所给题面的输出和原题有些不同 这道题当时想了很久很久&#xff0c;就是想不到怎么写。果然还是太 $ vegetable $ 了。首先我们可以肯定的是&#xff0c;我们不能暴力枚举&#xff…

LeetCode—美团2021秋招 001、002、003、004

美团2021秋招 001 小美的用户名、002 小美的仓库整理、003 小美的跑腿代购、004 小团的复制粘贴 题目描述&#xff1a; [001] 小美是美团的前端工程师&#xff0c;为了防止系统被恶意攻击&#xff0c;小美必须要在用户输入用户名之前做一个合法性检查&#xff0c;一个合法的用…

使用URI设计松散耦合的Metro应用程序

Metro风格应用程序意味着小型且高度集中。对于我们传统上为企业建立的、大规模的、单一的应用程序而言&#xff0c;我们可把它们重新想象成工作流的特定工 具。例如&#xff0c;你可能使用某款股票交易应用程序中的工具来查找并查看客户基本信息&#xff0c;而使用另一款应用程…

开源.NET企业级应用系统 OpenVista

看到倡议研究mono&#xff0c;我一直也在关注、跟踪Mono的发展&#xff0c;就是在项目中没有使用过。以前我介绍过一个iFolder Novell开源文件服务器.下面就来介绍一个Mono的一个应用OpenVista。http://www.cnblogs.com/shanyou/category/43483.html这里有许多Mono的相关资料。…

多个装饰器装饰一个函数

# def debug(func): # # def wrapper(): # # print ("[DEBUG]: enter {}()".format(func.__name__)) # # return func() # # return wrapper # # debug # # def say_hello(): # # print("hello!") # say_hello() # 添加功能并…

WKInterfaceImage 无法更新图片的问题

最近涉及到AppleWatch的相关项目&#xff0c;但有个奇怪问题无法解决&#xff0c;而且无法理解&#xff1a; 根据不同的用户操作&#xff0c;需要修改播放器的专辑图片。 不知道跟我的项目需求是不是有关系&#xff1a;我需要轮询共享空间&#xff0c;以拿取同步数据&#xff0…

LeetCode—美团2021秋招 006、007、008、009

美团2021秋招 006 小团的神秘暗号、007 小团的选调计划、008 小团无路可逃、009 小团的装饰物 题目描述&#xff1a; [006] 小团深谙保密工作的重要性&#xff0c;因此在某些明文的传输中会使用一种加密策略&#xff0c;小团如果需要传输一个字符串 S &#xff0c;则他会为这个…

POJ1390 Blocks——动态规划——pku1390

经典的动态规划&#xff0c;LRJ神牛的书上经典例题第一题。 开一个三维数组,f[i][j][k]表示将i~j这一段&#xff0c;连上后面的k个格子全部消去所能够获得的最大价值。 状态转移方程&#xff1a; f[i][j][k]Max{ Max{f[i][p][len[j]k]f[p1][j-1][0]}(color[p]color[j] and i<…

最大子矩阵求法详解

最大子矩阵&#xff08; $ s^2 $ 枚举障碍与 $ n \times m $ 悬线法&#xff09; 题目大意&#xff1a; 有 $ s $ 个障碍分布在一个 $ n\times m $ 的矩阵中。现在让你找出其中不包含任何一个障碍的最大子矩阵。 首先我们要引进一个新概念&#xff1a;&#xff08;极大子矩阵&a…

SQLSERVER数据仓库的构建与分析

实例构建过程与分析 1&#xff0e;现在以一个比较简单的实例来分析和探讨MS SQL SERVER 数据仓库的构建过程。实际上数据仓的构建是相当复杂的&#xff0c;他结合了数据仓库的前端技术和很强的业务要求。在这儿只是以一个简单的实例来说明他大致的构建流程。 2&#xff0e;构建…

基于Layui实现的树形菜单页面

基于Layui实现的树形菜单页面具体方法实现方法一&#xff1a;针对Layui模板的前后端统一更新1. 删除2. 添加3. 后端方法二&#xff1a;基于Dtree实现的纯前端树形增删改文中的组件地址具体方法实现 实现树形菜单&#xff0c;本文将给出两种实现方式。 针对Layui前端模板EasyW…

POJ 1723 Soldiers (中位数)

$ POJ~1723~Soldiers $ (中位数) $ solution: $ 这道题说难也不算太难&#xff0c;但是当时自己想的很矛盾。所以还是列一篇题解。 这道题首先比较容易看出来的就是&#xff1a;行和列是两个分开的问题&#xff0c;而且行的移动就是一个仓库选址的板子&#xff0c;直接求中位数…