Ex2: Find Hidden Number

実行時間制限:3 秒

メモリ制限:512 MiB

配点:500点

問題文

整数 nnオラクル OO が入力として与えられる。 00 以上 2n2^n 未満のある整数 LL が存在し、LLは2のべき (20,21,...2n1)(2^0, 2^1, ... 2^{n-1}) のいずれかであることがわかっている。オラクル OO0x<2n0\leq x\lt 2^n を満たす任意の整数 xx に対して、次式を満たす。

xnO{xn(x=L)xn(xL)\ket{x}_n \xrightarrow{O} \begin{cases} -\ket{x}_n & (x=L) \\ \ket{x}_n & (x\neq L) \end{cases}

ただし、 \oplus は排他的論理和を表す。

量子状態 0\ket{0} から、測定時に 0.90.9 以上の確率で L\ket{L} が観測されるような状態 ψ\ket{\psi} を作り出す操作を量子回路 qc\mathrm{qc} 上に実装せよ。

より正確な問題文

量子状態 0\ket{0}qc\mathrm{qc} を作用させた後の状態 ψ\ket{\psi} を、 aia_i を状態 i\ket{i} の複素振幅として次式で定義する。

ψ=i=02n1aii\ket{\psi} = \sum_{i=0}^{2^n-1} a_i\ket{i}

このとき、次式の条件を満たすような qc\mathrm{qc} を構築せよ。

aL20.9|a_L|^2 \geq 0.9

制約

  • 2n102 \leq n \leq 10
  • 量子回路の深さは 7575 を超えてはならない。
  • オラクル OO は深さ 11 の量子回路として与えられる。
  • 整数はリトルエンディアンにしたがってエンコードすること (例:100=1001\ket{100} = 1 \neq \ket{001})
  • グローバル位相 は問わない。
  • 提出されるコードは次のフォーマットにしたがうこと
from qiskit import QuantumCircuit
 
"""
You can apply oracle as follows:
qc.compose(o, inplace=True)
"""
 
 
def solve(n: int, o: QuantumCircuit) -> QuantumCircuit:
    qc = QuantumCircuit(n)
    # Write your code here:
 
    return qc

解答を提出するにはログインしてください。