乘风破浪:LeetCode真题_038_Count and Say
乘风破浪:LeetCode真题_038_Count and Say
一、前言
这一道题目,很类似于小学的问题,但是如果硬是要将输入和结果产生数值上的联系就会产生混乱了,因此我们要打破思维定势。
二、Count and Say
2.1 问题


2.2 分析与解决
这道题最难的其实是理解,因为描述的不尽其意,所以很难理解,其实就是根据最开始的字符串,不断的扩展,输入的N,代表的是经过N次之后的结果,与其中的结果没有任何关系。
/**
* 题目大意
* n=1时输出字符串1;n=2时,数上次字符串中的数值个数,因为上次字符串有1个1,
* 所以输出11;n=3时,由于上次字符是11,有2个1,所以输出21;n=4时,由于上次字符串是21,
* 有1个2和1个1,所以输出1211。依次类推,写个countAndSay(n)函数返回字符串。
*
* 解题思路
* 第一种情况:n<0时返回null。
* 第二种情况:当n=1时,返回1
* 第三种情况:当n>1时,假设n-1返回的字符串是s,对s的串进行处理,对不同的数字
* 进行分组比如112365477899,分成11,2,3,6,5,4,77,8,99。最有就2个1,
* 1个2,1个3,1个6,1个5,一个4,2个7,1个8,2个9,就是211213161614271829,返回此结果。
*/
理解题意之后,其他的就好办了:
public class Solution {
    public String countAndSay(int n) {
        if (n < 1) {
            return null;
        }
        String result = "1";
        for (int i = 2; i <= n; i++) {
            result = countAndSay(result);
        }
        return result;
    }
    public String countAndSay(String str) {
        StringBuilder builder = new StringBuilder(128);
        int count = 1;
        for (int i = 1; i < str.length(); i++) {
            if (str.charAt(i) == str.charAt(i - 1)) {
                count++;
            } else {
                builder.append(count);
                builder.append(str.charAt(i - 1));
                count = 1;
            }
        }
        builder.append(count);
        builder.append(str.charAt(str.length() - 1));
        return builder.toString();
    }
}
当然也可以用递归来做,其实道理是一样的,速度稍微慢一点:
public class Solution {
    public String countAndSay(int n) {
            if(n == 1) { return "1"; }
            String s = countAndSay(n-1);
            int i = 0;
            String out = "";
            while(i < s.length()) {
                int j = i+1;
                while(j < s.length() && s.charAt(i) == s.charAt(j)) {
                    j += 1;
                }
                out = out + (j-i) + s.charAt(i);
                i = j;
            }
            return out;
    }
}

三、总结
题目的理解非常重要,有的时候靠自己的猜测是不正确的。
乘风破浪:LeetCode真题_038_Count and Say的更多相关文章
- 乘风破浪:LeetCode真题_041_First Missing Positive
		乘风破浪:LeetCode真题_041_First Missing Positive 一.前言 这次的题目之所以说是难,其实还是在于对于某些空间和时间的限制. 二.First Missing Posi ... 
- 乘风破浪:LeetCode真题_040_Combination Sum II
		乘风破浪:LeetCode真题_040_Combination Sum II 一.前言 这次和上次的区别是元素不能重复使用了,这也简单,每一次去掉使用过的元素即可. 二.Combination Sum ... 
- 乘风破浪:LeetCode真题_039_Combination Sum
		乘风破浪:LeetCode真题_039_Combination Sum 一.前言 这一道题又是集合上面的问题,可以重复使用数字,来求得几个数之和等于目标. 二.Combination Sum ... 
- 乘风破浪:LeetCode真题_037_Sudoku Solver
		乘风破浪:LeetCode真题_037_Sudoku Solver 一.前言 这次我们对于上次的模型做一个扩展并求解. 二.Sudoku Solver 2.1 问题 2.2 分析与解决 这道题 ... 
- 乘风破浪:LeetCode真题_036_Valid Sudoku
		乘风破浪:LeetCode真题_036_Valid Sudoku 一.前言 有的时候对于一些基础知识的掌握,对我们是至关重要的,比如ASCII重要字符的表示,比如一些基本类型的长度. 二.Valid ... 
- 乘风破浪:LeetCode真题_035_Search Insert Position
		乘风破浪:LeetCode真题_035_Search Insert Position 一.前言 这次的问题比较简单,也没有限制时间复杂度,但是要注意一些细节上的问题. 二.Search Insert ... 
- 乘风破浪:LeetCode真题_034_Find First and Last Position of Element in Sorted Array
		乘风破浪:LeetCode真题_034_Find First and Last Position of Element in Sorted Array 一.前言 这次我们还是要改造二分搜索,但是想法却 ... 
- 乘风破浪:LeetCode真题_033_Search in Rotated Sorted Array
		乘风破浪:LeetCode真题_033_Search in Rotated Sorted Array 一.前言 将传统的问题进行一些稍微的变形,这个时候我们可能无所适从了,因此还是实践出真知, ... 
- 乘风破浪:LeetCode真题_032_Longest Valid Parentheses
		乘风破浪:LeetCode真题_032_Longest Valid Parentheses 一.前言 这也是非常有意思的一个题目,我们之前已经遇到过两个这种括号的题目了,基本上都要用到堆栈来解决,这次 ... 
随机推荐
- 第一次项目上Linux服务器(四:CentOS6下Mysql数据库的安装与配置(转))
			一.mysql简介 说到数据库,我们大多想到的是关系型数据库,比如mysql.oracle.sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱 ... 
- POJ 2262 Goldbach's Conjecture (打表)
			题目链接: https://cn.vjudge.net/problem/POJ-2262 题目描述: In 1742, Christian Goldbach, a German amateur mat ... 
- UVA 227 Puzzle(基础字符串处理)
			题目链接: https://cn.vjudge.net/problem/UVA-227 /* 问题 输入一个5*5的方格,其中有一些字母填充,还有一个空白位置,输入一连串 的指令,如果指令合法,能够得 ... 
- Huffman树与编码
			带权路径最小的二叉树称为最优二叉树或Huffman(哈夫曼树). Huffman树的构造 将节点的权值存入数组中,由数组开始构造Huffman树.初始化指针数组,指针指向含有权值的孤立节点. b = ... 
- el-upload源码跳坑2
			产品又加了一个需求,要求删除图片时候弹一个提示框,如果确定就直接发请求从服务器删除图片  一开始想的比较简单,直接在on-remove的钩子函数上做弹框提示,如果取消就撤销,代码如下: <el ... 
- MVC应用程序播放FLV视频,部分视图可多地方重复引用
			网页上播放Falsh之外,还有一种格式就是FLV的视频,也是最常见的.Insus.NET再想在MVC应用程序实现这功能. 实现这个功能,需要从网上下载一个叫vcastr22.swf.如果在网上找不到, ... 
- Eclipse在当前行之上插入一行
			在当前行之上插入一行快捷键: Ctrl + Shift + Enter 在当前行之下插入一行快捷键: Shift + Enter 
- 【Tomcat】Tomcat集群session管理
			网上资料汇总: 关于 tomcat 集群中 session 共享的三种方法 Tomcat7集群共享Session 基于redis进行统一管理 
- RabbitMQ安装教程
			最近几天在学习Spring Cloud,在学习Spring Cloud Config配置刷新使用Spring Cloud Bus时,其中用到消息代理组件RabbitMQ,在安装RabbitMQ的过程查 ... 
- ScheduledExecutorService的两种方法
			开发中,往往遇到另起线程执行其他代码的情况,用java定时任务接口ScheduledExecutorService来实现. ScheduledExecutorService是基于线程池设计的定时任务类 ... 
