leetcode刷题记录:递归1

leetcode 刷题记录:递归1

394:字符串解码
给定一个经过编码的字符串,返回它解码后的字符串。编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a 或 2[4] 的输入。
一眼看过去,应该用递归(或栈)。。。
对递归一直理解得不透彻,关键是递归入口和递归结束两个边界条件的确定。。在这道题目中,递归开始条件 遇到’[’ ,递归结束条件自然是遇到’]’ 或字符串遍历结束。。
数字字符、字母字符
具体代码小细节:
while(n-- > 0)
{

}
上述代码执行结束之后,n = -1,而不是 n=0;

很多人都认为这两段代码是等价的,我之前也误认为它们等价,但是实验证明这不是等价的。

第二段代码中,while(n–),当n=0时,并没有马上跳过循环条件和循环体,而是将循环条件执行完再跳过循环体。

原因:n–是一个整体,从编译器gcc角度看,先将n赋值给一个临时变量,然后自身减去1,返回的不是n而是临时变量。此时临时变量0,n为-1。故n–操作是一个整体,必须完整的执行完,不是割裂看的。之前,我误认为while中判断n为0时就直接结束。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值