diff options
| author | Noobie99 <noob999noob999@gmail.com> | 2024-02-02 19:52:58 +0100 |
|---|---|---|
| committer | Noobie99 <noob999noob999@gmail.com> | 2024-02-02 19:52:58 +0100 |
| commit | 009a9b1b085912eb96926597af8e5da96e8b4a9f (patch) | |
| tree | a88e676b596e00f8338110344b2865cdd26fd089 /math/transforms/bitwiseTransforms.cpp | |
| parent | 3aa6d97a451a7bac3667d35639c0d100b89e8933 (diff) | |
change fft, ntt and bitwise transforms
Diffstat (limited to 'math/transforms/bitwiseTransforms.cpp')
| -rw-r--r-- | math/transforms/bitwiseTransforms.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/math/transforms/bitwiseTransforms.cpp b/math/transforms/bitwiseTransforms.cpp new file mode 100644 index 0000000..7d1f80d --- /dev/null +++ b/math/transforms/bitwiseTransforms.cpp @@ -0,0 +1,12 @@ +void fft(vector<ll>& a, bool inv = false) { + int n = sz(a); + for (int s = 1; s < n; s *= 2) { + for (int i = 0; i < n; i += 2 * s) { + for (int j = i; j < i + s; j++) { + ll& u = a[j], &v = a[j + s]; + tie(u, v) = inv ? pair(v - u, u) : pair(v, u + v); // AND + //tie(u, v) = inv ? pair(v, u - v) : pair(u + v, u); //OR + //tie(u, v) = pair(u + v, u - v); // XOR + }}} + //if (inv) for (ll& x : a) x /= n; // XOR (careful with MOD) +} |
