#include long long int fact[1000016]; int main() { long long int l, r, m; scanf("%lld %lld %lld", &l, &r, &m); long long int ans = 0; long long int i; fact[0] = 1; for (i = 1; i < 1000006; i++) fact[i] = fact[i - 1] * i % m; long long int v = 1; for (i = 0; i < l; i++) v = v * fact[i] % m; for (i = l; i < m && i <= r; i++) { v = v * fact[i] % m; ans += v; ans %= m; } printf("%lld\n", ans); return 0; }