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>
    
  • 相关阅读:
    eclipse报错 : One or more constraints have not been satisfied.
    关于一个计算机同时装两个jdk对应两个eclipse
    开发测试类2
    工作中测试类1
    Spring 读取classpath下的文件存到map里面
    CentOS6下安装JDK并且部署tomcat容器
    ConOS安装mysql5.7 及简单配置
    用sqlyog迁移mysql数据库
    FindBugs缺陷库
    使用NumberPicker定制自己喜欢的Date&TimePicker
  • 原文地址:https://www.cnblogs.com/bianzhuo/p/9463293.html
Copyright © 2011-2022 走看看