ABC 186 | E - Throne
7235 단어 경업자gcd확장 유클리드 호제법역원tech
문제.
해법
K마다 이동하고 N번째 X주 뒤에 도착하면 되기 때문에 아래의 연합식을 만들 수 있다.
Kx + S\equiv 0\(\bmod\N)
Kx\equiv -S\(\bmod\N)
따라서 이상은 다음과 같은 전형적인 연합방정식의 문제를 해결하는 것이다.
ax\equiv b\(\bmod\m)
이후 해설과 마찬가지로 해설을 참조할 수 있다.
코드
Tips 설치
modint
와 역원 사용 가능inv
#include <bits/stdc++.h>
#include <atcoder/all>
using namespace std;
using namespace atcoder;
using ll = long long;
using ld = long double;
using uint = unsigned int;
using ull = unsigned long long;
const int MOD = 1e9 + 7;
// ax ≡ b (mod m)を解く
ll solve(ll a, ll b, ll m) {
ll d = gcd(gcd(a, b), m);
a /= d;
b /= d;
m /= d;
ll g = gcd(a, m);
if (b % g != 0) return -1;
modint::set_mod(m);
modint res = modint(b) * modint(a).inv();
return res.val();
}
int main() {
ll t;
cin >> t;
for (int i = 0; i < t; i++) {
ll n, s, k;
cin >> n >> s >> k;
auto v = solve(k, -s, n);
cout << v << endl;
}
}
참고 자료
Reference
이 문제에 관하여(ABC 186 | E - Throne), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://zenn.dev/wapa5pow/articles/abc186-e-bfe5a97e38142f92639a텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)