Movatterモバイル変換


[0]ホーム

URL:



In EnglishПо-русски
Enter |Register



VK Cup 2022 - Отборочный раунд (Engine)
Finished
→ Practice?
Want to solve the contest problems after the official contest ends? Just register for practice and you will be able to submit solutions.
→ Virtual participation
Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.
→ Problem tags
combinatorics
dp
math
trees
*2700
No tag edit access
→ Contest materials
The problem statement has recently been changed.View the changes.
×
F. Bracket Insertion
time limit per test
4 seconds
memory limit per test
512 megabytes
input
standard input
output
standard output

Vika likes playing with bracket sequences. Today she wants to create a new bracket sequence using the following algorithm. Initially, Vika's sequence is an empty string, and then she will repeat the following actions $$$n$$$ times:

  • Choose a place in the current bracket sequence to insert new brackets uniformly at random. If the length of the current sequence is $$$k$$$, then there are $$$k+1$$$ such places: before the first bracket, between the first and the second brackets, $$$\ldots$$$, after the $$$k$$$-th bracket. In particular, there is one such place in an empty bracket sequence.
  • Choose string "()" with probability $$$p$$$ or string ")(" with probability $$$1 - p$$$ and insert it into the chosen place. The length of the bracket sequence will increase by $$$2$$$.

A bracket sequence is calledregular if it is possible to obtain a correct arithmetic expression by inserting characters '+' and '1' into it. For example, sequences "(())()", "()", and "(()(()))" are regular, while ")(", "(()", and "(()))(" are not.

Vika wants to know the probability that her bracket sequence will be a regular one at the end. Help her and find this probability modulo $$$998\,244\,353$$$ (see Output section).

Input

The only line contains two integers $$$n$$$ and $$$q$$$ ($$$1 \le n \le 500$$$; $$$0 \le q \le 10^4$$$). Here $$$n$$$ is equal to the number of bracket insertion operations, and the probability that Vika chooses string "()" on every step of the algorithm is equal to $$$p = q \cdot 10^{-4}$$$.

Output

Print the probability that Vika's final bracket sequence will be regular, modulo $$$998\,244\,353$$$.

Formally, let $$$M = 998\,244\,353$$$. It can be shown that the answer can be expressed as an irreducible fraction $$$\frac{p}{q}$$$, where $$$p$$$ and $$$q$$$ are integers and $$$q \not \equiv 0 \pmod{M}$$$. Output the integer equal to $$$p \cdot q^{-1} \bmod M$$$. In other words, output such an integer $$$x$$$ that $$$0 \le x < M$$$ and $$$x \cdot q \equiv p \pmod{M}$$$.

Examples
Input
1 7500
Output
249561089
Input
2 6000
Output
519087064
Input
5 4000
Output
119387743
Note

In the first example, Vika will get a regular bracket sequence() with probability $$$p = \frac{3}{4}$$$, and she will get an irregular bracket sequence)( with probability $$$1 - p = \frac{1}{4}$$$. The sought probability is $$$\frac{3}{4}$$$, and $$$249\,561\,089 \cdot 4 \equiv 3 \pmod{998\,244\,353}$$$.

In the second example, the sought probability is $$$\frac{11}{25}$$$.


Codeforces (c) Copyright 2010-2025 Mike Mirzayanov
The only programming contests Web 2.0 platform
Server time:Apr/04/2025 16:14:56 (n2).
Desktop version, switch tomobile version.
Privacy Policy |Terms and Conditions
Supported by
TON
 
ITMO University
 
 
 
 
User lists
 
 
Name

[8]ページ先頭

©2009-2025 Movatter.jp