算法课程笔记——如何倍增

快速幂

读入量大于1e5不要用cin读入,要用也要关闭同步流

第i个o次方的父亲


 

#include<bits/stdc++.h>usingnamespacestd;
#definemaxn 110000#definell long longintn, a[maxn], f[maxn][40];
intquery(intl, intr){
    intk = (int)(log((r - l + 1) * 1.0) / log(2.0));
    returnmin(f[l][k], f[r - (1<< k) + 1][k]);
}

intmain(){
    scanf("%d", &n);
    for(inti = 1; i <= n; ++ i )
        scanf("%d", &a[i]), f[i][0] = a[i];
    for(intj = 1; j <= (int)(log(n * 1.0) / log(2.0)); ++ j )
        for(inti = 1; i + (1<< j) - 1<= n; ++ i )
            f[i][j] = min(f[i][j - 1], f[i + (1<< (j - 1))][j - 1]);
    intq;
    scanf("%d", q);
    while(q -- )
    {
        intl, r;
        scanf("%d%d", &l, &r);
        printf("%d\n", query(l, r));
    }
   
    return0;
}

#include<bits/stdc++.h>usingnamespacestd;
#definemaxn 110000#definell long longintn, a[maxn], f[maxn][40];
intquery(intl, intr){
    intk = (int)(log((r - l + 1) * 1.0) / log(2.0));
    returnmin(f[l][k], f[r - (1<< k) + 1][k]);
}

intmain(){
    scanf("%d", &n);
    for(inti = 1; i <= n; ++ i )
        scanf("%d", &a[i]), f[i][0] = a[i];
    for(intj = 1; j <= (int)(log(n * 1.0) / log(2.0)); ++ j )
        for(inti = 1; i + (1<< j) - 1<= n; ++ i )
            f[i][j] = min(f[i][j - 1], f[i + (1<< (j - 1))][j - 1]);
    intq;
    scanf("%d", q);
    while(q -- )
    {
        intl, r;
        scanf("%d%d", &l, &r);
        printf("%d\n", query(l, r));
    }
   
    return0;
}

相关推荐

  1. 最近公共祖先(lca)倍增算法【模板】

    2024-04-29 14:04:04       20 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-29 14:04:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-29 14:04:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-29 14:04:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-29 14:04:04       18 阅读

热门阅读

  1. ChatGPT使用指南:Prompt简单提示词

    2024-04-29 14:04:04       14 阅读
  2. 图神经网络 | 混合神经网络模型GCTN地铁客流预测

    2024-04-29 14:04:04       19 阅读
  3. GeoServer改造Springboot源码八(图层预览设计)

    2024-04-29 14:04:04       15 阅读
  4. 用 hdparm 释放 Linux 的力量

    2024-04-29 14:04:04       16 阅读
  5. 《21天学通C++》实现继承(1)

    2024-04-29 14:04:04       14 阅读
  6. k8s:使用Fabric 来访问api-server

    2024-04-29 14:04:04       12 阅读
  7. css实现dom脱离文档流定位固定位置

    2024-04-29 14:04:04       15 阅读
  8. Elasticsearch索引监控全面解析

    2024-04-29 14:04:04       16 阅读
  9. mysql的触发器,存储过程

    2024-04-29 14:04:04       15 阅读
  10. Elasticsearch索引状态管理实战指南

    2024-04-29 14:04:04       18 阅读
  11. Redis(五) Redis锁

    2024-04-29 14:04:04       16 阅读
  12. Ubuntu 22.04 安装Oracle 11g Express Edition

    2024-04-29 14:04:04       14 阅读
  13. CSS基础:4类组合选择器以及5个注意事项

    2024-04-29 14:04:04       18 阅读