当前位置: 首页 > news >正文

同余方程组、拓展中国剩余定理 excrt

同余方程组、拓展中国剩余定理 excrt

公式:\(x \equiv b_i(\bmod\ a_i)\) ,即 \((x - b_i) \mid a_i\)

int n; LL ai[maxn], bi[maxn];
inline int mypow(int n, int k, int p) {int r = 1;for (; k; k >>= 1, n = n * n % p)if (k & 1) r = r * n % p;return r;
}
LL exgcd(LL a, LL b, LL &x, LL &y) {if (b == 0) { x = 1, y = 0; return a; }LL gcd = exgcd(b, a % b, x, y), tp = x;x = y, y = tp - a / b * y;return gcd;
}
LL excrt() {LL x, y, k;LL M = bi[1], ans = ai[1];for (int i = 2; i <= n; ++ i) {LL a = M, b = bi[i], c = (ai[i] - ans % b + b) % b;LL gcd = exgcd(a, b, x, y), bg = b / gcd;if (c % gcd != 0) return -1;x = mul(x, c / gcd, bg);ans += x * M;M *= bg;ans = (ans % M + M) % M;}return (ans % M + M) % M;
}
int main() {cin >> n;for (int i = 1; i <= n; ++ i) cin >> bi[i] >> ai[i];cout << excrt() << endl;return 0;
}

求解连续按位异或

\(\mathcal O(1)\) 复杂度计算 \(0\oplus1\oplus\dots\oplus n\)

unsigned xor_n(unsigned n) {unsigned t = n & 3;if (t & 1) return t / 2u ^ 1;return t / 2u ^ n;
}
i64 xor_n(i64 n) {if (n % 4 == 1) return 1;else if (n % 4 == 2) return n + 1;else if (n % 4 == 3) return 0;else return n;
}

高斯消元求解线性方程组

题目大意:输入一个包含 \(N\) 个方程 \(N\) 个未知数的线性方程组,系数与常数均为实数(两位小数)。求解这个方程组。如果存在唯一解,则输出所有 \(N\) 个未知数的解,结果保留两位小数。如果无数解,则输出 \(\tt{}X\) ,如果无解,则输出 \(\tt{}N\)

const int N = 110;
const double eps = 1e-8;
LL n;
double a[N][N];
LL gauss(){LL c, r;for (c = 0, r = 0; c < n; c ++ ){LL t = r;for (int i = r; i < n; i ++ )    //找到绝对值最大的行 if (fabs(a[i][c]) > fabs(a[t][c]))t = i;if (fabs(a[t][c]) < eps) continue;for (int j = c; j < n + 1; j ++ ) swap(a[t][j], a[r][j]);    //将绝对值最大的一行换到最顶端for (int j = n; j >= c; j -- ) a[r][j] /= a[r][c];    //将当前行首位变成 1for (int i = r + 1; i < n; i ++ )    //将下面列消成 0 if (fabs(a[i][c]) > eps)for (int j = n; j >= c; j -- )a[i][j] -= a[r][j] * a[i][c];r ++ ;}if (r < n){for (int i = r; i < n; i ++ )if (fabs(a[i][n]) > eps)return 2;return 1;}for (int i = n - 1; i >= 0; i -- )for (int j = i + 1; j < n; j ++ )a[i][n] -= a[i][j] * a[j][n];return 0;
}
int main(){cin >> n;for (int i = 0; i < n; i ++ )for (int j = 0; j < n + 1; j ++ )cin >> a[i][j];LL t = gauss();if (t == 0){for (int i = 0; i < n; i ++ ){if (fabs(a[i][n]) < eps) a[i][n] = abs(a[i][n]);printf("%.2lf\n", a[i][n]);}}else if (t == 1) cout << "Infinite group solutions\n";else cout << "No solution\n";return 0;
}
http://www.rkmt.cn/news/29220.html

相关文章:

  • Apache POI 在 Linux 无图形界面环境下因字体配置问题导致Excel导出失败的解决方案 - 详解
  • 扩展欧几里得 exgcd
  • 防爆模乘
  • 20232314 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 最小割树 Gomory-Hu Tree
  • 图论常见结论及例题
  • 最短路径树(SPT问题)
  • 多源汇最短路(APSP问题)
  • 单源最短路径(SSSP问题)
  • 最近公共祖先 LCA
  • 题解:P3343 [ZJOI2015] 地震后的幻想乡
  • 暂存:P14214 [COI 2010] 圆圈 / KOLO
  • QMPlayer2解析
  • 2025年10月广州单位办公室搬家公司全景解析报告,基于专业测评的技术、性能及市场优势深度分析
  • 权威调研榜单:东莞工厂装修公司OP3榜单好评深度解析
  • 2025年口碑好的FPC离型纸,环氧胶离型纸推荐TOP生产厂家
  • 2025年口碑好的数字地磅,电子汽车衡地磅厂家推荐及选择建议
  • 2025年10月进口艺术漆厂家全景解析报告,基于专业测评的技术、性能及市场优势深度分析
  • 最大公约数 gcd
  • 2025年上海注册公司/上海代理记账公司最新推荐榜,聚焦企业服务品质与特色业务竞争力深度剖析
  • 2025 年国内无缝钢管厂家最新推荐榜:20#/Q355 系列 / 合金管优质品牌权威测评及选购指南
  • 2025年优秀的冷却塔,鼓风式冷却塔定制定做
  • 2025年比较好的车铣复合机床,动力刀塔车铣复合品牌厂家排行榜
  • 2025年质量好的阻燃尼龙改性颗粒,耐腐蚀尼龙改性颗粒推荐TOP生产厂家
  • 详细介绍:力扣2245. 转角路径的乘积中最多能有几个尾随零
  • 2025年优秀的空气治理光触媒,自清洁光触媒最新TOP排名厂家
  • 2025年优秀的手动喷砂机,通过式喷砂机最新TOP厂家推荐
  • 完整教程:kotlin图算法
  • 2025年专业的立式空调机组,恒温恒湿空调机组厂家最新推荐排行榜
  • 亚稳态危害,