【leetcode】38. (Easy)Count and Say

本文详细解析了计数与描述序列问题的算法实现,通过迭代和字符串操作,逐步生成序列的每一个元素。从基本原理出发,介绍了如何计算序列中每个数字的出现次数,并将其转化为下一个序列的输入,实现了从n=1到任意n值的序列生成。

题目链接

解题思路:
这道题的意思是从1开始:
1: 读作1个1,即11,下一个就是11
11:读作2个1,即21,下一个就是21
21:读作1个2,1个1,下一个就是1211

依次类推

我的想法是控制两个循环while1 while2,在外循环进行迭代判断,比如如果输入n=3,就循环2次,从n=1开始迭代计算n=3时的情况;
内循环具体计算每个单元stmp的内容,比如当上一个s是“21”时,第一个stmp=“12”即1个2,循环到第二个stmp是“11”即1个1

看了网上的代码,基本上都是这个思路

提交代码:

class Solution {
	public String countAndSay(int n) {
		if (n == 1)		return "1";

		String stmp,s = "1",snext="";
		int p,charcnt, charvalue;
		while (n > 1) { // 迭代的次数
			p = 0;
			while (p < s.length()) {
				charcnt = 0;
				charvalue = s.charAt(p);
				while (p < s.length() && s.charAt(p) == charvalue) {
					p++;
					charcnt++;
				}
				stmp = Integer.toString(charcnt);
				stmp += String.valueOf((int) (charvalue - '0'));
				snext += stmp;
			}
			s = snext;snext = "";n--;
		}
		return s;
	}
}

运行结果:
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值