当前位置: 首页 > news >正文

企业网站icp备案云盘网页版登录

企业网站icp备案,云盘网页版登录,开网店做代理的公司网站,办办网文章目录 题目题目分析思路解法正常解法优化解法 题目 题目链接:力扣 91. 解码方法 备用链接:https://leetcode.cn/problems/decode-ways/description/ 题目分析 1.首先我们知道题目给定A~Z编码为1 ~26 ,而数字十一字符串的形式给出所以…

文章目录

  • 题目
  • 题目分析
  • 思路
  • 解法
    • 正常解法
    • 优化解法

题目

题目链接:力扣 91. 解码方法
备用链接:https://leetcode.cn/problems/decode-ways/description/
在这里插入图片描述
在这里插入图片描述

题目分析

1.首先我们知道题目给定A~Z编码为1 ~26 ,而数字十一字符串的形式给出所以需要转换成整型
2.在解码部分我们可以了解到分为两种可能
(1)单独一个数字能否解码,如图:
在这里插入图片描述

(2)两个数字能否解码,如图:
在这里插入图片描述
3.返回是解法的总数
4.字符串s的范围在1 ~ 100之间
5.字符串s 只包含数字,并且可能包含前导零

思路

首先我们想到用动态规划的解法
那么进入动态规划几个基本步骤:
1. 确定dp状态表示什么
一般来说在dp问题中都是以i位置为起点表示什么什么或者以i位置为结尾表示什么什么…
那么我们就想一下这道题是正常给的字符串s我们解码的时候从左向右解码所以我们就这样来确定
dp[i]:以i为结尾时,解码方法的总数

2. 状态转移方程的表示
我们可以分为两种情况如图:
在这里插入图片描述

解读:

  • 单独解码的时候只有数字在1 ~ 9 之间才有对应字母,即解码成功
  • 单独解码时候一个字母解码成功不代表全解码成功,而我们dp[i]的意思是以i为结尾时,解码方法的总数,那么之后到达最后一个字符s[i]也解码成功才算一种方法,所以相较于i-1的解码只是在后面又加了一个字符进行判断能否成功解码,所以成功也还是dp[i-1]
  • 解码失败那么前面的解码都白费所以就不加 dp[i-1]这种方法
  • 组合解码数字在10 ~ 26而不是0 ~ 26是防止==“06”/“01”==等这种情况
  • 最后dp[i]的状态转移方程
  • 就是dp[i]=if(1 ~ 9 ){dp[i-1]}+if(10 ~ 26){dp[i-2]}如果单独解码成功则加dp[i-1]如果组合解码成功就加dp[i-2]

3. 初始化
因为我们会用到 i -1 和 i - 2 所以我们初始化的时候要初始化dp[0]和dp[1]两个
在这里插入图片描述
4. 填表方向
我们要先知道dp[i-2],dp[i-1]才能推出dp[i],所以方向是从左向右

5. 返回值
返回dp[size-1],给定字符串的最后一项

解法

正常解法

class Solution {
public:int numDecodings(string s) {int size=s.size();int dp[110]={0};int num10=0,num1=0,num=0;if(s[0]!='0') dp[0]=1;if(size==1) return dp[0];//如果字符串s中只有一个字符那个只有一种情况直接返回if(s[1]!='0'&&s[0]!='0') dp[1]+=1;num10=s[0]-'0',num1=s[1]-'0',num=num10*10+num1;//i-1作为十位,i作为个位if(num>=10&&num<=26) dp[1]+=1;for(int i=2;i<size;i++){if(s[i]!='0') dp[i]+=dp[i-1];//解码成功加dp[i-1]num10=s[i-1]-'0',num1=s[i]-'0',num=num10*10+num1;if(num>=10&&num<=26) dp[i]+=dp[i-2];//解码成功加dp[i-2]}return dp[size-1];//返回最后一个总数减一}
};

优化解法

在上面的代码中我们初始化和正常的填表操作有很大的重复所以我们改进一下
在这里插入图片描述
我们人为添加一个dp[0]的虚拟位,其余位依次向下挪一位,这样在填表的操作中就能实现从第二位开始填表

这种方法的注意事项:

  1. 下标的映射关系

我们在多加了一个虚拟下标之后就等于dp的位多了一位所以我们在获取s的时候要s[i-1]才能获取到对应dp[i]的s的值。

  1. 人为填写的值要正确(一般情况下都是0,本题就要计算下)

我们填写的时候dp[2]=dp[1]+dp[0],dp[1]是不会出错的,dp[2]我们又能直接算出来,所以dp[0]我们就可以直接得到,本题dp[0]要填1。

class Solution {
public:int numDecodings(string s) {int size=s.size();int dp[110]={0};int num10=0,num1=0,num=0;dp[0]=1;if(s[1-1]!='0') dp[1]=1;if(size==1) return dp[1];for(int i=2;i<=size;i++){if(s[i-1]!='0') dp[i]+=dp[i-1];num10=s[i-1-1]-'0',num1=s[i-1]-'0',num=num10*10+num1;if(num>=10&&num<=26) dp[i]+=dp[i-2];}return dp[size];}
};
http://www.hkea.cn/news/950263/

相关文章:

  • 网站地址地图怎么做网页制作的软件有哪些
  • 如何用万网建设网站口碑营销策划方案
  • 做网站的基础架构东莞seo建站公司
  • 嘉兴做网站的哪家好龙岗网站制作
  • 论坛做网站好吗百度官方网页
  • 微信开发者工具获取系统日期seo优化一般包括
  • 怎么用文本做网站百度排行榜风云榜
  • 未来网站开发需求多搜索网站有哪几个
  • 网站建设 成都郑州高端网站制作
  • 快站怎么做淘客网站深圳关键词
  • 做网站时如何去掉网站横条小红书软文案例
  • 图虫南宁百度快速排名优化
  • 上城网站建设app推广文案
  • 网站建设特点宁波seo搜索引擎优化公司
  • 地产商网站建设网球新闻最新消息
  • 做爰全过程网站免费的视频谷歌seo搜索引擎
  • 怎么架设网站seo推广培训
  • 自己网站做问卷调查网页设计学生作业模板
  • 清远企业网站排名深圳网站建设系统
  • 互助平台网站建设费用卡点视频免费制作软件
  • 上海做b2b国际网站公司排名优化公司电话
  • 裙晖wordpress重庆seo整站优化
  • 乌克兰网站后缀谷歌浏览器下载电脑版
  • 建设部网站撤销注册资质的都是公职人员吗正规网络公司关键词排名优化
  • 杂志网站建设推广方案铜川网络推广
  • 网站建设后怎么搜索引擎优化解释
  • 网站建设维护 天博网络成都营销型网站制作
  • 秦皇岛北京网站建设百度广告投放电话
  • 团购做的比较好的网站营销推广ppt
  • 网站怎么做网站地图重庆网站制作公司哪家好