N = int(input()) MOD = 998244353 DP = [i for i in range(N + 1)] R = {} for i in range(2, N + 1): t = DP[i] if t != 1: if t not in R: R[t] = 0 for j in range(i, N + 1, i): DP[j] //= t R[t] += 1 M = R[2] DP = [0] * (M + 1) L = list(R.values()) for i in range(1, M + 1): t = 1 for j in range(len(L) - 1, -1, -1): if L[j] < i: L.pop() else: n = L[j] // i t *= n + 1 t %= MOD DP[i] = (t - 1) % MOD ans = 0 for i in range(1, M + 1): if i != M: DP[i] -= DP[i + 1] DP[i] %= MOD ans += DP[i] * i % MOD ans %= MOD print(ans)