第K个语法符号
在第一行我们写上一个 0。接下来的每一行,将前一行中的0替换为01,1替换为10。
给定行数 N 和序数 K,返回第 N 行中第 K个字符。(K从1开始)
输入: N = 1, K = 1
输出: 0
输入: N = 2, K = 1
输出: 0
输入: N = 2, K = 2
输出: 1
输入: N = 4, K = 5
输出: 1
解释:
第一行: 0
第二行: 01
第三行: 0110
第四行: 01101001
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/k-th-symbol-in-grammar
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
分析
- 第N行 第K个的符号,是由第N-1行的 (K+1)/2 个符号决定的,递归处理
- 第1行1个符号就是0
- 0 --> 01 ,1 --> 10,规律是:如果K是奇数,则和上行符号一致,否则取反
算法
class Solution {
public:
int kthGrammar(int N, int K) {
if(N == 1)
return 0;
int v = kthGrammar(N-1,(K+1)>>1);
return (K&1) ? v : !v;
}
};