#include long long int modpow(long long int a, long long int n, long long int p) { long long int res = 1; for (; n > 0; n /= 2, a = a * a % p) if (n % 2 > 0) res = res * a % p; return res; } long long int x[1000006]; int main() { long long int n, m; scanf("%lld %lld", &m, &n); long long int i; for (i = 0; i < n; i++) scanf("%lld", &x[i + 1]); n += 2; x[0] = 0; x[n - 1] = m + 1; const long long int p = 998244353; long long int ans = 0, c, inv6 = modpow(6, p - 2, p); for (i = 1; i < n; i++) { c = x[i] - x[i - 1] - 1; ans += c % p * (c % p + 1) % p * (2 * c % p + 1) % p * inv6 % p; ans %= p; } printf("%lld\n", ans); return 0; }