## https://yukicoder.me/problems/no/1348 MOD = 998244353 def main(): N = int(input()) # nodeの数の期待値 x_n = 0 p = 1 for n in range(N): a = (p * pow(N - n, MOD - 2, MOD)) % MOD a *= n a %= MOD x_n += a x_n %= MOD p *= ((N - n - 1) * pow(N - n, MOD - 2, MOD)) % MOD p %= MOD x_n *= N x_n %= MOD x_e = 0 p = 1 for n in range(N - 1): a = (p * pow(N - n, MOD - 2, MOD)) % MOD a *= 2 a %= MOD a *= n a %= MOD x_e += a x_e %= MOD p *= ((N - n - 2) * pow(N- n, MOD -2, MOD)) % MOD p %= MOD x_e *= (N - 1) x_e %= MOD xxx = 1 for i in range(1, N + 1): xxx *= i xxx %= MOD x_n *= xxx x_n %= MOD x_e *= xxx x_e %= MOD answer = (x_n - x_e) %MOD print(answer) if __name__ == "__main__": main()