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时就直接结束。