CF BUDDY
← Problems·

1237E · Balanced Binary Search Trees

2400 · dp, math

Problem: Recall that a binary search tree is a rooted binary tree, whose nodes each store a key and each have at most two distinguished subtrees, left and right. The key in each node must be greater than any key stored in the left subtree, and less than any key stored in the right subtree.

The depth of a vertex is the number of edges on the simple path from the vertex to the root. In particular, the depth of the root is 00.

Let's call a binary search tree perfectly balanced if there doesn't exist a binary search tree with the same number of vertices that has a strictly smaller sum of depths of its vertices.

Let's call a binary search tree with integer keys striped if both of the following conditions are satisfied for every vertex vv:

  • If vv has a left subtree whose root is uu, then the parity of the key of vv is different from the parity of the key of uu.
  • If vv has a right subtree whose root is ww, then the parity of the key of vv is the same as the parity of the key of ww.

You are given a single integer nn. Find the number of perfectly balanced striped binary search trees with nn vertices that have distinct integer keys between 11 and nn, inclusive. Output this number modulo 998244353998\,244\,353.

Input Format: The only line contains a single integer nn (1n1061 \le n \le 10^6), denoting the required number of vertices.

Output Format: Output the number of perfectly balanced striped binary search trees with nn vertices and distinct integer keys between 11 and nn, inclusive, modulo 998244353998\,244\,353.

Note: In the first example, this is the only tree that satisfies the conditions:

In the second example, here are various trees that don't satisfy some condition:

Sample Cases

Case 1

Input

4

Output

1

Case 2

Input

3

Output

0

Similar problems

00:00:00
Loading editor…
Welcome! I'm your coding tutor for this problem. Use the chips below to reveal stored hints or get AI feedback on your code. I'll guide you step by step — never giving away the solution.

Sign in to unlock AI tutor feedback