首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
核桃小饼干
大兴安岭职业学院 产品经理
发布于北京
关注
已关注
取消关注
@牛客题解官:
题解 | #把数字翻译成字符串#
题目主要信息:字母到数字分别为1-26映射,没有0输入的数字是字符串,故非常大,超过了long long的表示范围但凡出现11-19,21-26的就可能出现两种译码结果求总后的译码结果种类举一反三:学习完本题的思路你可以解决如下题目:BM62.斐波那契数列BM63.跳台阶BM64.最小花费爬楼梯方法:动态规划(推荐使用)知识点:动态规划动态规划算法的基本思想是:将待求解的问题分解成若干个相互联系的子问题,先求解子问题,然后从这些子问题的解得到原问题的解;对于重复出现的子问题,只在第一次遇到的时候对它进行求解,并把答案保存起来,让以后再次遇到时直接引用答案,不必重新求解。动态规划算法将问题的解决方案视为一系列决策的结果思路:对于普通数组1-9,译码方式只有一种,但是对于11-19,21-26,译码方式有可选择的两种方案,因此我们使用动态规划将两种方案累计。具体做法:step 1:用辅助数组dp表示前i个数的译码方法有多少种。step 2:对于一个数,我们可以直接译码它,也可以将其与前面的1或者2组合起来译码:如果直接译码,则dp[i]=dp[i−1]dp[i]=dp[i-1]dp[i]=dp[i−1];如果组合译码,则dp[i]=dp[i−2]dp[i]=dp[i-2]dp[i]=dp[i−2]。step 3:对于只有一种译码方式的,选上种dp[i−1]dp[i-1]dp[i−1]即可,对于满足两种译码方式(10,20不能)则是dp[i−1]+dp[i−2]dp[i-1]+dp[i-2]dp[i−1]+dp[i−2]step 4:依次相加,最后的dp[length]dp[length]dp[length]即为所求答案。图示:Java实现代码:import java.util.*;public class Solution { public int solve (String nums) { //排除0 if(nums.equals("0")) return 0; //排除只有一种可能的10 和 20 if(nums == "10" || nums == "20") return 1; //当0的前面不是1或2时,无法译码,0种 for(int i = 1; i < nums.length(); i++){ if(nums.charAt(i) == '0') if(nums.charAt(i - 1) != '1' && nums.charAt(i - 1) != '2') return 0; } int[] dp = new int[nums.length() + 1]; //辅助数组初始化为1 Arrays.fill(dp, 1); for(int i = 2; i <= nums.length(); i++){ //在11-19,21-26之间的情况 if((nums.charAt(i - 2) == '1' && nums.charAt(i - 1) != '0') || (nums.charAt(i - 2) == '2' && nums.charAt(i - 1) > '0' && nums.charAt(i - 1) < '7')) dp[i] = dp[i - 1] + dp[i - 2]; else dp[i] = dp[i - 1]; } return dp[nums.length()]; }}C++实现代码:class Solution {public: int solve(string nums) { //排除0 if(nums == "0") return 0; //排除只有一种可能的10 和 20 if(nums == "10" || nums == "20") return 1; //当0的前面不是1或2时,无法译码,0种 for(int i = 1; i < nums.length(); i++){ if(nums[i] == '0') if(nums[i - 1] != '1' && nums[i - 1] != '2') return 0; } //辅助数组初始化为1 vector<int> dp(nums.length() + 1, 1); for(int i = 2; i <= nums.length(); i++){ //在11-19,21-26之间的情况 if((nums[i - 2] == '1' && nums[i - 1] != '0') || (nums[i - 2] == '2' && nums[i - 1] > '0' && nums[i - 1] < '7')) dp[i] = dp[i - 1] + dp[i - 2]; else dp[i] = dp[i - 1]; } return dp[nums.length()]; }};Python代码实现:class Solution: def solve(self , nums: str) -> int: #排除0 if nums == "0": return 0 #排除只有一种可能的10 和 20 if nums == "10" or nums == "20": return 1 #当0的前面不是1或2时,无法译码,0种 for i in range(1, len(nums)): if nums[i] == '0': if nums[i - 1] != '1' and nums[i - 1] != '2': return 0 #辅助数组初始化为1 dp = [1 for i in range(len(nums) + 1)] for i in range(2, len(nums) + 1): #在11-19,21-26之间的情况 if (nums[i - 2] == '1' and nums[i - 1] != '0') or (nums[i - 2] == '2' and nums[i - 1] > '0' and nums[i - 1] < '7'): dp[i] = dp[i - 1] + dp[i - 2] else: dp[i] = dp[i - 1] return dp[len(nums)]复杂度分析:时间复杂度:O(n)O(n)O(n),两次遍历都是单层空间复杂度:O(n)O(n)O(n),辅助数组dp
点赞 32
评论 16
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
01-21 19:42
武汉大学 Java
20260116【宇树科技】面试算法真题(共1题)
题目1:实现最大正向匹配分词算法
查看1道真题和解析
点赞
评论
收藏
分享
01-21 09:23
厦门大学 驱动开发
双非小菜鸡的秋招历程
前言上数十年,今年是招聘环境最差的一年,但下数十年,今年有可能是招聘环境最好的一年。——来源秋招中遇到的不知名的某hr找工作本身就是运气+实力,甚至在菜鸡看来运气占比更高,有的时候不要总是怪自己(倒也不是为自己开脱哈),尽人事听天命,不要自己内耗。菜鸡在这里总结一下自己的整个一个找工作情况,一方面是从群众中来到群众中去,感谢找工作的时候中各位大佬们的资料与建议;另一方面是希望能为更多的小伙伴们提供微不足道的帮助。一、楼主自己情况菜鸡自己是来源于东三省某双非大学(排名很低的那种),本硕自动化,硕士研究方向是纯仿真(跟控制和编程无任何关系),无正式实习(导师派出去干过杂活),无高水平期刊论文,无高...
点赞
评论
收藏
分享
2025-12-18 11:59
广州南方学院 C++
🤡
路过看一眼不说话都要被踹一脚吗
牛客78682892...:
直接点还好,总比要了简历也不回的强
点赞
评论
收藏
分享
01-15 10:49
安徽新华学院 Python
cc简历
27寒假想找个实习,找不到咩
点赞
评论
收藏
分享
昨天 14:41
魔门塔(苏州)科技有限公司_感知算法工程师(准入职员工)
9377游戏内推,9377游戏内推码
erlang后端开发面试首先笔试,现场做:第一部分选择题(5题左右):大部分与排序、查找、时间复杂度、稳定性这几个知识点有关。有一题是通过二叉树的中序和后序反推原二叉树。总体难度:低第二部分简答题:1.TCP与UDP有什么不同? 2.写冒泡排序3.写出题目代码的递归结果9377游戏2026届春招启动!【公司简介】9377集团成立于2011年,是集研发、发行和平台运营于一体的全球化综合型互联网游戏公司。【热招岗位】 游戏策划类、美术设计类、市场推广类、游戏运营类、技术开发类【丰厚福利】定制化激励方案、季/年度优秀奖励、四餐供应、全勤奖励、带薪年假、特色带薪假、年度体检、交通补贴、高温补贴、年度团...
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
J人永远闲不下来于是去提前实习
1993
2
...
牛客吐槽大会 | 有槽不吐,留着过年?吐完领现金红包,痛快!
1971
3
...
拥抱AI,程序员的最后出路
1558
4
...
mentor视角下的优秀实习生
1540
5
...
真正会被取代的,是你心里面的幻觉
1515
6
...
大厂提前实习对AI开发的新感悟
1254
7
...
努力挣钱的意义具象化了
1242
8
...
马斯克最新炸裂采访,AI会带走一半工作岗位,普通人将何去何从?
1194
9
...
去独角兽做龙头还是去大厂做凤尾
1128
10
...
我身材再曼妙,也没有我的工资好笑!
1050
创作者周榜
更多
正在热议
更多
#
牛客吐槽大会
#
2228次浏览
54人参与
#
机械人你知道哪些单休企业
#
82995次浏览
413人参与
#
今年春招是金一银二嘛?
#
7427次浏览
89人参与
#
参加完秋招的机械人,还参加春招吗?
#
103515次浏览
682人参与
#
1月小结:你过的开心吗?
#
1686次浏览
50人参与
#
抛开难度不谈,你最想去哪家公司?
#
3721次浏览
100人参与
#
为什么有人零实习也能进大厂?
#
4642次浏览
110人参与
#
AI时代的工作 VS 传统时代的工作,有哪些不同?
#
7860次浏览
190人参与
#
没关系,至少我的__很曼妙
#
3564次浏览
63人参与
#
赚钱的意义在这一刻具象化
#
3724次浏览
90人参与
#
你的第一家实习公司是什么档次?
#
3930次浏览
67人参与
#
当你问AI“你会取代我的工作吗”,它说_?
#
3432次浏览
120人参与
#
你的landing期是如何度过的?
#
7971次浏览
147人参与
#
机械人春招想让哪家公司来捞你?
#
379145次浏览
3139人参与
#
AI求职实录
#
2929次浏览
90人参与
#
除了Java,最推荐学什么技术?
#
5414次浏览
139人参与
#
一人一道大厂面试题
#
114073次浏览
1263人参与
#
设计人如何选offer
#
187062次浏览
864人参与
#
你在职场上见过哪些“水货”同事
#
30696次浏览
167人参与
#
简历中的项目经历要怎么写?
#
287724次浏览
3801人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务