#include <atcoder/modint>

using mint = atcoder::modint998244353;

#include <iostream>

int main() {
  long long N, M, K;
  std::cin >> N >> M >> K;

  if (M <= K) {
    std::cout << mint(M).pow(2 * N).val() << "\n";
    return 0;
  }

  mint ans = 0;
  ans += mint(K).pow(2 * N) * mint(M - K + 1);
  ans -= mint(K - 1).pow(2 * N) * (M - K);

  std::cout << ans.val() << "\n";

  return 0;
}