当前位置:网站首页>leetcode 38. 外观数列
leetcode 38. 外观数列
2022-08-09 21:54:00 【_刘小雨】
作者简介:C/C++ 、Golang 领域耕耘者,创作者
个人主页:作者主页
活动地址:CSDN21天学习挑战赛
题目来源: leetcode官网
如果感觉博主的文章还不错的话,还请关注 、点赞 、收藏🧡三连支持一下博主哦~~~
题目描述
给定一个正整数 n ,输出外观数列的第 n 项。
「外观数列」是一个整数序列,从数字 1 开始,序列中的每一项都是对前一项的描述。
你可以将其视作是由递归公式定义的数字字符串序列:
countAndSay(1) = “1”
countAndSay(n) 是对 countAndSay(n-1) 的描述,然后转换成另一个数字字符串。
前五项如下:
1
11
21
1211
111221
第一项是数字 1
描述前一项,这个数是 1 即 “ 一 个 1 ”,记作 “11”
描述前一项,这个数是 11 即 “ 二 个 1 ” ,记作 “21”
描述前一项,这个数是 21 即 “ 一 个 2 + 一 个 1 ” ,记作 “1211”
描述前一项,这个数是 1211 即 “ 一 个 1 + 一 个 2 + 二 个 1 ” ,记作 “111221”
要 描述 一个数字字符串,首先要将字符串分割为 最小 数量的组,每个组都由连续的最多 相同字符 组成。然后对于每个组,先描述字符的数量,然后描述字符,形成一个描述组。要将描述转换为数字字符串,先将每组中的字符数量用数字替换,再将所有描述组连接起来。
例如,数字字符串 “3322251” 的描述如下图:
示例1:
输入:n = 1
输出:“1”
解释:这是一个基本样例。
示例2:
输入:n = 4
输出:“1211”
解释:
countAndSay(1) = “1”
countAndSay(2) = 读 “1” = 一 个 1 = “11”
countAndSay(3) = 读 “11” = 二 个 1 = “21”
countAndSay(4) = 读 “21” = 一 个 2 + 一 个 1 = “12” + “11” = “1211”
🧡 算法分析
此题方法是用双指针
算法思路比较简单
算法步骤:
- 直接利用双指针,前面记录数字的个数,后面记录该位置的字符
代码实现
class Solution {
public:
string countAndSay(int n) {
string s = "1"; // 开始第一项
// 求第n次, 所以需要遍历n - 1 次
for(int i =0; i < n - 1; i ++)
{
string t;
// 找前一段每段相同的数
for(int j = 0; j < s.size(); )
{
int k = j + 1;
while(k < s.size() && s[k] == s[j]) k ++;
t += to_string(k - j) + s[j];
j = k;
}
s = t;
}
return s;
}
};
执行结果:
时间复杂度分析
其中遍历一次, 时间复杂度为O(n)
如果觉得对你有帮助的话:
点赞,你的认可是我创作的动力!
🧡 收藏,你的青睐是我努力的方向!
️ 评论,你的意见是我进步的财富!
边栏推荐
- 【GORM】模型关系-HasMany关系
- 简单问题窥见数学
- Easyui 表单验证「建议收藏」
- 【微服务~Nacos】Nacos之配置中心
- Liver all night to write a thirty thousand - word all the commands the SQL database, function, speaks clearly explain operators, content is rich, proposal collection + 3 even high praise!
- Install win virtual machine on VMware
- Quotefancy ,提供鼓舞人心语录的壁纸网站 - 倾城之链
- AI Knows Everything: Building and Deploying a Sign Language Recognition System from Zero
- Xiaohei leetcode's refreshing rainy day trip, just finished eating Yufei Beef Noodles, Mala Tang and Beer: 112. Path Sum
- Activiti7审批流
猜你喜欢
【微服务~Nacos】Nacos之配置中心
AI Knows Everything: Building and Deploying a Sign Language Recognition System from Zero
任务流执行器是如何工作的?
How to Make Your Company Content GDPR Compliant
Converting angles to radians
电脑系统重装后怎么用打印机扫描出文件?
MLOps的演进历程
TRUNCATE表之后空间未释放
Xiaohei's leetcode journey: 94. Inorder traversal of binary trees (supplementary Morris inorder traversal)
APP自动化测试框架-UiAutomator2基础入门
随机推荐
聊天尬死名场面,你遇到过吗?教你一键获取斗图表情包,晋升聊天达人
UML类图五种关系的代码实现[通俗易懂]
ACM MM 2022 | Cloud2Sketch: 长空云作画,AI笔生花
Flask's routing (app.route) detailed
2.1.5 大纲显示问题
基于ABP的AppUser对象扩展
SecureCRT background color
np中的round函数,ceil函数与floor函数
5个 Istio 访问外部服务流量控制最常用的例子,你知道几个?
[Cloud Native] 4.2 DevOps Lectures
[Implementation of the interface for adding, deleting, checking, and modifying a double-linked list]
Install win virtual machine on VMware
README_Albumentations
Usage of placeholder function in Tensorflow
navicat 快捷键
mysql multi-table left link query
LeetCode26:删除有序数组中的重复项
SQLi-LABS Page-2 (Adv Injections)
几种绘制时间线图的方法
TF使用constant生成数据