zoukankan      html  css  js  c++  java
  • 同余定理及其应用

    转载https://blog.csdn.net/QQ1353217816/article/details/79706975

        同余定理两个整数同时除以一个整数得到的余数相同,则二整数同余。记作a ≡ b(mod m)。

    1. 同余定理的加法乘法应用

    • (a + b) % m = (a % m + b % m) % m
    设 a = k1 * m + r1,b = k2 * m + r2
    则 (a + b) % m = ((k1 * m + r1) + (k2 * m + r2)) % m
                   = ((k1 + k2) * m + (r1 + r2)) % m
                   = (r1 + r2) % m
                   = (a % m + b % m) % m
    所以 (a + b) % m = (a % m + b % m) % m

    • (a * b) % m = ((a % m) * (b % m)) % m
    设 a = k1 * m + r1,b = k2 * m + r2
    则 (a * b) % m = ((k1 * m + r1) * (k2 * m + r2)) % m
                   = (k1 * k2 * m^2 + (k1 * r2 + k2 * r1) * m + r1 * r2) % m
                   = (r1 * r2) % m
                   = ((a % m) * (b % m)) % m
    所以 (a * b) % m = ((a % m) * (b % m)) % m

    2. 高精度取模

    • 高精度对单精度取模

        一个高精度数对一个数取余,可以把高精度数看成各位数的权值与个位数乘积的和。

        比如1234 = ((1 * 10 + 2) * 10 + 3) * 10 + 4,对这个数进行取余运算就是上面基本加和乘的应用。

    1. #include<iostream>
    2. #include<string>
    3. using namespace std;
    4. int main(){
    5. string a;
    6. int b;
    7. cin >> a >> b;
    8. int len = a.length();
    9. int ans = 0;
    10. for(int i = 0; i < len; i++){
    11. ans = (ans * 10 + a[i] - ‘0’) % b;
    12. }
    13. cout << ans << endl;
    14. return 0;
    15. }

    • 快速幂取模

        将幂拆解为多个底数的平方次的积,如果指数为偶数,把指数除以2,并让底数的平方次取余,如果指数为奇数,就把多出来的底数记录下来,再执行偶数次的操作。

    1. #include<iostream>
    2. using namespace std;
    3. int PowerMod(int a, int b, int c){
    4. int ans = 1;
    5. a = a % c;
    6. while(b > 0){
    7. if(b&1){
    8. ans *= (a % c);
    9. }
    10. b >>= 1;
    11. a = (a * a) % c;
    12. }
    13. ans %= c;
    14. return ans;
    15. }
    16. int main(){
    17. int a, b, c;
    18. cin >> a >> b >> c;
    19. cout << PowerMod(a, b, c) << endl;
    20. return 0;
    21. }

                </div>
    
  • 相关阅读:
    IplImage, CvMat, Mat 的关系
    neon memory copy
    基于v4l2的webcam应用, 本地预监
    makefile写法实例
    Ubuntu 12.04 使用Eclipse搭建C/C++编译环境
    xapp1167与TRD14.4 关系
    v3学院带你一次性认清UART、RS-232、RS-422、RS-485的区别
    v3学院教你学习-task和function的异同
    寒假参加V3
    FPGA培训学习心得
  • 原文地址:https://www.cnblogs.com/bianzhuo/p/9463293.html
Copyright © 2011-2022 走看看