用途
与えられた自然数を素因数分解する.
計算量
使い方
例えばprimeFactrize(12)をすると, {(2,2),(3,1)}が返ってくる.これはを意味している.
実装
vector<pair<int, int>> primeFactorize(int n) { vector<pair<int, int>> res; for (int a = 2; a * a <= n; ++a) { if (n % a == 0) { res.push_back({a, 0}); while (n % a == 0) ++res.back().second, n /= a; } } if (n != 1) res.push_back({n, 1}); return res;}Verify
//TODO