golang 刷leetcode:统计打字方案数
发布时间 - 2025-07-18 00:00:00 点击率:次alice在用手机给bob发送信息时,使用的按键和字母的对应关系如下图所示。
为了输入一个字母,Alice需要按对应按键的次数,等于该字母在按键上的位置。例如,要输入字母 's',Alice需要按 '7' 四次;要输入字母 'k',Alice需要按 '5' 两次。
需要注意的是,数字 '0' 和 '1' 没有对应的字母,因此Alice不会使用它们。
然而,由于传输错误,Bob收到的不是Alice发送的字母信息,而是按键的字符串信息。例如,Alice发送的信息为 "bob",Bob会收到字符串 "2266622"。
现在给你一个字符串 pressedKeys,表示Bob收到的字符串,请你返回Alice可能发送的总文字信息种类数。
由于答案可能非常大,需要对 10^9 + 7 取模后返回。
示例 1:
输入:pressedKeys = "22233"
输出:8
解释:
Alice可能发送的文字信息包括:
"aaadd", "abdd", "badd", "cdd", "aaae", "abe", "bae" 和 "ce"。
总共有8种可能的信息,因此返回8。
示例 2:
输入:pressedKeys = "222222222222222222222222222222222222"
输出:82876089
解释:
总共有2082876103种Alice可能发送的文字信息。
由于需要对10^9 + 7取模,返回2082876103 % (10^9 + 7) = 82876089。
提示:
- 1
-
pressedKeys只包含数字 '2' 到 '9'。
解题思路:
-
这个问题可以转化为爬楼梯问题,具体情况如下:
A. 如果连续两个字符相同,可以爬1步或2步。
B. 如果连续三个字符相同,可以爬1步、2步或3步。
C. 如果连续四个或更多字符相同,且是7或9,可以爬1步、2步、3步或4步。
D. 如果字符不相同,只能爬一步。
这是一个类似于斐波那契数列的问题。
可以通过动态规划来解决。
代码实现:
function countTexts(pressedKeys) {
const dp = new Array(pressedKeys.length + 1).fill(0);
dp[0] = 1;
for (let i = 1; i <= pressedKeys.length; i++) {
let tmp = 0;
if (i >= 4 && pressedKeys[i-1] === pressedKeys[i-2] && pressedKeys[i-1] === pressedKeys[i-3] && pressedKeys[i-1] === pressedKeys[i-4] && (pressedKeys[i-1] === '7' || pressedKeys[i-1] === '9')) {
tmp = (dp[i-1] + dp[i-2] + dp[i-3] + dp[i-4]) % 1000000007;
} else if (i >= 3 && pressedKeys[i-1] === pressedKeys[i-2] && pressedKeys[i-1] === pressedKeys[i-3]) {
tmp = (dp[i-1] + dp[i-2] + dp[i-3]) % 1000000007;
} else if (i >= 2 && pressedKeys[i-1] === pressedKeys[i-2]) {
tmp = (dp[i-
1] + dp[i-2]) % 1000000007;
} else {
tmp = dp[i-1];
}
dp[i] = tmp;
}
return dp[pressedKeys.length];
}目前这个实现的空间复杂度是O(n),但可以进一步优化到O(1),因为我们只需要使用到dp数组中的四个变量。因此,可以使用一个长度为4的数组来优化空间复杂度。
优化后的代码:
function countTexts(pressedKeys) {
const dp = [1, 1, 1, 1];
for (let i = 1; i <= pressedKeys.length; i++) {
let tmp = 0;
if (i >= 4 && pressedKeys[i-1] === pressedKeys[i-2] && pressedKeys[i-1] === pressedKeys[i-3] && pressedKeys[i-1] === pressedKeys[i-4] && (pressedKeys[i-1] === '7' || pressedKeys[i-1] === '9')) {
tmp = (dp[3] + dp[2] + dp[1] + dp[0]) % 1000000007;
} else if (i >= 3 && pressedKeys[i-1] === pressedKeys[i-2] && pressedKeys[i-1] === pressedKeys[i-3]) {
tmp = (dp[3] + dp[2] + dp[1]) % 1000000007;
} else if (i >= 2 && pressedKeys[i-1] === pressedKeys[i-2]) {
tmp = (dp[3] + dp[2]) % 1000000007;
} else {
tmp = dp[3];
}
dp[0] = dp[1];
dp[1] = dp[2];
dp[2] = dp[3];
dp[3] = tmp;
}
return dp[3];
}
# linux
# golang
# 字符串
# 斐波那契数列
# Length
# leetcode
# 总共有
# 的是
# 给你
# 只需
# 两次
# 这个问题
# 请你
# 这是一个
# 可以通过
# 用手
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何为不同团队 ID 动态生成多个独立按钮
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
如何在万网开始建站?分步指南解析
如何快速重置建站主机并恢复默认配置?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
Laravel安装步骤详细教程_Laravel环境搭建指南
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Swift中循环语句中的转移语句 break 和 continue
,交易猫的商品怎么发布到网站上去?
Python文件异常处理策略_健壮性说明【指导】
简历在线制作网站免费版,如何创建个人简历?
Laravel用户密码怎么加密_Laravel Hash门面使用教程
零服务器AI建站解决方案:快速部署与云端平台低成本实践
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
如何在云虚拟主机上快速搭建个人网站?
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
如何撰写建站申请书?关键要点有哪些?
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
免费视频制作网站,更新又快又好的免费电影网站?
如何挑选高效建站主机与优质域名?
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
网站图片在线制作软件,怎么在图片上做链接?
Laravel如何发送系统通知?(Notification渠道示例)
php 三元运算符实例详细介绍
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
微信小程序 wx.uploadFile无法上传解决办法
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
Laravel如何自定义错误页面(404, 500)?(代码示例)
EditPlus中的正则表达式实战(6)
Java类加载基本过程详细介绍
Laravel如何使用Service Container和依赖注入?(代码示例)
googleplay官方入口在哪里_Google Play官方商店快速入口指南
百度浏览器如何管理插件 百度浏览器插件管理方法
高防服务器:AI智能防御DDoS攻击与数据安全保障
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
香港服务器选型指南:免备案配置与高效建站方案解析
微信小程序 HTTPS报错整理常见问题及解决方案
如何用美橙互联一键搭建多站合一网站?


1] + dp[i-2]) % 1000000007;
} else {
tmp = dp[i-1];
}
dp[i] = tmp;
}
return dp[pressedKeys.length];
}