C#刷遍Leetcode面试题系列连载(2): No.38 - 报数

前言

前文传送门:

上篇文章中我们主要科普了刷 LeetCode 对大家的作用,今天咱们就正式进行 LeetCode 算法题分析。很多人都知道计算机中有种思想叫 递归,相应地也出现了很多算法。解决递归问题的要点有如下几个:

  • 找出递归的关系

    比如,给个数列 f(n),常见的递归关系是后面的项 f(n+1)与前面几项之间的关系,比如斐波那契数列的递归关系为: f(n+1) = f(n-1) + f(n)

  • 进行递归调用

  • 把握好递归出口

但实际情况下,递归算法的复杂度比较难用数学公式来描述,自由度太大,我们常常需要将递归算法优化成迭代(非递归)的算法。

今天我们来分析一个递归描述的字符串问题,后面我们会给出相应的 非递归 算法。

640?wx_fmt=png

今天要给大家分析的面试题是 LeetCode 上第 38 号问题,

LeetCode - 38. 报数

https://leetcode-cn.com/problems/count-and-say/

题目描述

报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下:

1.     1	
2.     11	
3.     21	
4.     1211	
5.     111221

1 被读作 "one 1" ( "一个一") , 即 1111 被读作 "two 1s" ( "两个一"), 即 2121 被读作 "one 2", " one1""一个二" , "一个一") , 即 1211

给定一个正整数 n(1 ≤ n ≤ 30),输出报数序列的第 n 项。

注意:整数顺序将表示为一个字符串。

示例 1:

输入: 1	
输出: "1"

示例 2:

输入: 4	
输出: "1211"

  • 贡献者: LeetCode

  • 题目难度: Easy

  • 通过率: 52.67%

相关话题

  • 字符串

    https://leetcode.com/tag/string

相似题目

  • 字符串的编码与解码

    https://leetcode-cn.com/problems/encode-and-decode-strings/

    难度: 中等

  • 压缩字符串

    https://leetcode-cn.com/problems/string-compression/

    难度:简单

解题思路:

首先,这个题按题目描述来看并不是很容易理解。

一句话解释清楚就是: 第 n+1个字符串是第 n个字符串的读法,所以这个数列的每一项可列举如下:

① 1

② 11

③ 21

④ 1211

⑤ 111221

⑥ 312211

...

而读上一个字符串也是有要求的,就是统计连续出现的字符数量,一旦出现新字符就重新开始统计。

于是最后的结果为: count1 digit1 count2 digit2 ... count n digit n (去掉其中的空格)

接下来,我们该考虑下代码该怎么写了。我们在文章开头提到了下面会才有非递归的思路来做,具体可以这么做:

  • 首先我们有个基准,就是第一项 f(n) = 1

  • 有了第1项,后面每一项只与它之前的项满足明确的关系,于是想推算出第n项目,我们需要迭代 n-1 次

  • 想办法获得每一段 count i digit i 拼接串,从左向右顺序扫描之即可,遇到相同的数字计数器+1,遇到不同的置为1重新累加

  • 拼接每一段 count i digit i 字符串,作为输入进行下一轮迭代

AC的代码为:

public class Solution	
{	public string CountAndSay(int n)	{	if (n == 1)	return "1";	string res = "1";            	for (int i = 0; i < n - 1; i++)    // 只需迭代n-1次是因为数列第一个数f(1)已知为 1	{	StringBuilder buffer = new StringBuilder();	char currentChar = default(char);	int currentCharCount = 0;	currentChar = res[0];	foreach (var ch in res)   // res用作pre(数列前一项)	{	if (ch == currentChar)	currentCharCount++;	else	{	buffer.Append(currentCharCount.ToString()).Append(currentChar); 	/* 一旦遇到不同的数字,就追加到拼接字符串 */	currentChar = ch;	currentCharCount = 1;	}	}	buffer.Append(currentCharCount.ToString()).Append(currentChar); 	/* 把最后一个数字及它的数量加上 */	res = buffer.ToString();  // 更新res,用作post(数列后一项)	}	return res;	}	
}

640?wx_fmt=png

运行结果:

执行用时 : 100ms, 在所有 C# 提交中击败了 97.58%的用户

代码要点:

  • 字符串比较常见的拼接方式是使用 +,但频繁拼接会降低运行速度,比较快的方式是使用 StringBuilder进行拼接,最后用个 ToString()函数即可

  • 注意最后要将最后一个数字及它的数量加上

相应的,如需测试,本地可执行的代码为:

using System;	
using System.Text;	
namespace leetcode38	
{	public class Solution	{	public string CountAndSay(int n)	{	if (n == 1)	return "1";	string res = "1";            	for (int i = 0; i < n - 1; i++)	{	StringBuilder buffer = new StringBuilder();	char currentChar = default(char);	int currentCharCount = 0;	currentChar = res[0];	foreach (var ch in res)	{	if (ch == currentChar)	currentCharCount++;	else	{	buffer.Append(currentCharCount.ToString()).Append(currentChar);	currentChar = ch;	currentCharCount = 1;	}	}	buffer.Append(currentCharCount.ToString()).Append(currentChar);	res = buffer.ToString();	}	return res;	}	public static void Main()	{	var sol = new Solution();	Console.WriteLine(sol.CountAndSay(8));	}	}	
}

相应代码已经上传到github:

https://github.com/yanglr/Leetcode-CSharp/tree/master/leetcode38

参考资料:

https://www.cnblogs.com/TenosDoIt/p/3776356.html

End


640?wx_fmt=jpeg


smiley_66.png你点的每一个"在看"

我都当成了喜欢!

640?wx_fmt=gif

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

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

相关文章

Bumblebee微服务网关之负载策略

作为一个微服务网关&#xff0c;提供不同负载策略配置是一项非常重要的主要功能&#xff1b;在这方向Bumblebee提供了非常好的支持。Bumblebee可以针对不同路径制定各自的负载策略&#xff0c;更重要的是这些调整都可以在网关运行过程动态调整&#xff01;动态策略调整可以更好…

FastDFS分布式文件系统设计原理

FastDFS是一个开源的轻量级分布式文件系统&#xff0c;由跟踪服务器&#xff08;tracker server&#xff09;、存储服务器&#xff08;storage server&#xff09;和客户端&#xff08;client&#xff09;三个部分组成&#xff0c;主要解决了海量数据存储问题&#xff0c;特别适…

14年百度深度学习校招题目

一、简答题1.深度神经网络目前有哪些成功的应用&#xff1f;简述原因。(10分) 2.列举不同进程共享数据的方式&#xff08;至少三种&#xff09;。(10分) 3.对于N个样本&#xff0c;每个样本为D维向量&#xff0c;采用欧式距离使用KNN做类预测。(10分) 1).给出预测时间复杂度。 …

HDFS分布式文件系统设计原理

Hadoop分布式文件系统(HDFS)是一种被设计成适合运行在通用硬件上的分布式文件系统。HDFS是一个高度容错性的系统&#xff0c;适合部署在廉价的机器上。它能提供高吞吐量的数据访问&#xff0c;非常适合大规模数据集上的应用。要理解HDFS的内部工作原理&#xff0c;首先要理解什…

Magicodes.IE已支持导出Word、Pdf和Html

关于Magicodes.IE导入导出通用库&#xff0c;通过导入导出DTO模型来控制导入和导出&#xff0c;支持Excel、Word、Pdf和Html。GitHub地址&#xff1a;https://github.com/xin-lai/Magicodes.IE特点需配合相关导入导出的DTO模型使用&#xff0c;支持通过DTO以及相关特性控制导入…

AOP框架Dora.Interception 3.0 [1]: 编程体验

.NET Core正式发布之后&#xff0c;我为.NET Core度身定制的AOP框架Dora.Interception也升级到3.0。这个版本除了升级底层类库&#xff08;.NET Standard 2.1&#xff09;之外&#xff0c;我还对它进行大范围的重构甚至重新设计。这次重构大部分是在做减法&#xff0c;其目的在…

分布式缓存——一致性哈希算法

本文主要来自&#xff1a;http://www.zsythink.net/archives/1182 摘录防丢失 一致性哈希算法定义 一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希&#xff08;DHT&#xff09;实现算法&#xff0c;设计目标是为了解决因特网中的热点(Hot spot)问题&#xff0c;初…

H264学习_基本数据结构

&#xfeff;&#xfeff;原文地址:http://blog.csdn.net/yangzhongxuan/article/details/8003494 名词解释 场和帧 &#xff1a; 视频的一场或一帧可用来产生一个编码图像。在电视中&#xff0c;为减少大面积闪烁现象&#xff0c;把一帧分成两个隔行的场。 片&#xff1a…

【巴马火麻茶】调节三高、治疗失眠、排毒减肥,轻松get长寿的秘密!

水&#xff0c;无色无味&#xff0c;是人类的生命源泉对于长期坐办公室的程序员朋友来说每日都得喝水但又觉得寡淡的白开水缺少点乐趣于是&#xff0c;茶叶就成了大家泡水的首选今天&#xff0c;队长要为大家介绍一款养生好茶巴马火麻茶每天一杯&#xff0c;轻松get长寿的秘密火…

「合规」震惊!地图可视化竟能如此玩,零门槛,全免费,效果远胜主流作图工具!...

在数据可视化领域&#xff0c;早晚会遇上地图可视化的需求&#xff0c;一个高大上的地图可视化&#xff0c;瞬间拔高整个报告的层次。Excel催化剂有幸接触并将地图可视化完全落地于Excel中完成。相对主流Python、R、PowerBI等作图工具&#xff0c;在易用性、灵活性和功能的强大…

Opencv SVM demo

&#xfeff;&#xfeff;转载自http://www.opencv.org.cn/opencvdoc/2.3.2/html/doc/tutorials/ml/introduction_to_svm/introduction_to_svm.html 支持向量机 (SVM) 是一个类分类器&#xff0c;正式的定义是一个能够将不同类样本在样本空间分隔的超平面。 换句话说&#xff…

BeetleX之FastHttpApi服务使用详解

BeetleX是一个轻量级高性能的开源TCP通讯应用框架&#xff0c;通过BeetleX可以轻松扩展不同场的TCP应用服务和客户端组件。框架开源地址:https://github.com/IKende/BeetleX组件特点高性能TCP通讯组件,轻易实现百万级RPS通讯交互提供完善的会话管理机制和协议分析规则提供简洁的…

康威定律

本文来自&#xff1a;http://www.dockone.io/article/2691 1、概述 微服务架构是一种非常流行的新概念&#xff0c;即便可供以借鉴的经验比较少&#xff0c;当然不能阻挡它成为热门话题与研究对象。 令人惊讶地是&#xff0c;其实微服务的概念早在五十多年前就已经被提出&…

Cannot find or open the PDB file

&#xfeff;&#xfeff;http://blog.chinaunix.net/uid-11765716-id-3074932.html 遇到问题 SVM_demo.exe (Win32): Loaded ...\SVM_demo\Debug\SVM_demo.exe. Symbols loaded. SVM_demo.exe (Win32): Loaded C:\Windows\System32\ntdll.dll. Symbols loaded. SVM_demo.exe…

基于ASP.NET Core 3.0的ABP v0.21已发布

在微软发布仅仅一个小时后, 基于ASP.NET Core 3.0的ABP v0.21也紧跟着发布了.v0.21没有新功能.它只是升级到稳定的ASP.NET Core 3.0. 查看v0.20发行说明以获取新功能,增强功能和错误修复.关于v1.0ABP框架越来越接近v1.0.我们打算在今年10月中旬发布1.0. 现在,我们将完善测试和文…

SOA和微服务

一、面向服务的架构SOA SOA代表了面向服务的架构。 SOA是一种使用松耦合的黑盒子服务构建业务应用的体系架构&#xff0c;这些服务可以通过编排连接在一起以实现特定的功能。 面向服务的架构&#xff08;Service-Oriented Architecture&#xff09;是一种软件体系结构&#x…

[ASP.NET Core 3框架揭秘] 跨平台开发体验: Windows [上篇]

微软在千禧年推出 .NET战略&#xff0c;并在两年后推出第一个版本的.NET Framework和IDE&#xff08;Visual Studio.NET 2002&#xff0c;后来改名为Visual Studio&#xff09;&#xff0c;如果你是一个资深的.NET程序员&#xff0c;相信传统的.NET应用的开发方式已经深深地烙印…

下一代微服务架构基础:ServiceMesh?

最近&#xff0c;ServiceMesh(服务网格) 概念在社区里头非常火&#xff0c;有人提出 2018 年是 ServiceMesh 年&#xff0c;还有人提出 ServiceMesh 是下一代的微服务架构基础。作为架构师&#xff0c;如果你现在还不了解 ServiceMesh 的话&#xff0c;是否感觉有点落伍了&…

ASP.NET Core 2.0 Web API项目升级到ASP.NET Core 3.0概要笔记

本文结构先决条件升级目标框架&#xff08;Target Framework&#xff09;的版本过时的IHostingEnvironment与IApplicationLifetime对象Endpoint Routing与AddMvc中间件Swashbuckle.AspNetCore总结手头有个ASP.NET Core 2.0的项目&#xff0c;打算将里面的依赖包进行一个版本升级…

常见消息队列对比

一、消息队列概述 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用解耦&#xff0c;异步消息&#xff0c;流量削锋等问题&#xff0c;实现高性能&#xff0c;高可用&#xff0c;可伸缩和最终一致性架构。目前使用较多的消息队列有ActiveMQ&#xff0c;Rabbit…