#include using namespace std; constexpr int Z = 998244353; int main() { int n; cin >> n; // case 1: for at least 2, a: 1 b, c: 1 b // b: 1 !b, other: 1 b or 0 !b // n*((n-1)^(n-1)-(n-2)^(n-1)-(n-1)*(n-2)^(n-2))*(n-1) // case 2: a: 1 b, b: 1 c, other: 0 !b // n*(n-1)*(n-2)*(n-2)^(n-2) // case 3: a: 1 b, b: 1 a, // other: 0 !b, for at least 1, 0 a // n*(n-1)*((n-2)^(n-2)-(n-3)^(n-2)) // case 4: b: 1 a // other: 0 !b // n*(n-1)*(n-2)^(n-1) // add: n*(n-1)^(n-1)-n*(n-1)*(n-3)^(n-2) int p1 = n; for (int i = 0; i < n; i++) { p1 = 1ll * p1 * (n - 1) % Z; } int p2 = 1ll * n * (n - 1) % Z; for (int i = 0; i < n - 2; i++) { p2 = 1ll * p2 * (n - 3) % Z; } cout << (p1 - p2 + Z) % Z << endl; return 0; }