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

server/2024/11/17 4:58:01/

快速幂

读入量大于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;
}


http://www.ppmy.cn/server/22991.html

相关文章

数据结构与算法-迭代加深搜索算法

迭代加深搜索&#xff08;Iterative Deepening Search&#xff0c;IDS&#xff09; 是一种常用的搜索算法&#xff0c;结合了深度优先搜索的空间效率和广度优先搜索的完备性和最优性。其核心思想是重复进行深度优先搜索&#xff0c;但每次都增加搜索的深度限制&#xff0c;直到…

VR全景创业项目应该如何开展?未来有市场吗?

伴随着5G网络的发展&#xff0c;VR全景得到了众多的关注和提升。与此同时&#xff0c;各行各业都开始关注自身产业在互联网的展示效果&#xff0c;因为年轻一代的生活已经离不开互联网&#xff0c;而VR全景在互联网上的3D展示效果能给商家带来流量&#xff0c;提升营业额。 随着…

使用Docker搭建Nacos集群

本次是在Mac的M1版本上使用Docker搭建Nacos集群的详细步骤&#xff0c;并记录了一些遇到的问题及解决方案。 搭建涉及&#xff1a;1个Nginx 3个Nacos 1个MySQL 使用版本&#xff1a;Nginx为1.22.0&#xff0c;Nacos为2.0.3&#xff0c;MySQL为8.0.30 一、创建虚拟网络 因为M…

数据结构 第六章 树与二叉树(三)

&#x1f680; 【考纲要求】二叉树的遍历 &#x1f680; 第六章第一节内容请查看此链接 树的基本概念 &#x1f680; 第六章第二节内容请查看此链接 二叉树的定义、四种特殊的二叉树和二叉树的存储结构 三、二叉树的遍历和线索二叉树 3.1二叉树的遍历 所谓的二叉树的遍历就是…

VUE3与Uniapp 二 (响应式变量ref)

<template><!-- 响应式数据变量是双项绑定 --><view>{{num}}</view><view>{{string}}</view><view>{{arry[2]}}</view><view>{{obj.name}}</view> </template><script setup>// 使用ref定义响应式数据…

三维点云处理-聚类(上)

聚类&#xff08;Cluster&#xff09;是数据处理中常用的一种分析方法&#xff0c;聚类的目标是将相似的数据对象划分到同一个簇中&#xff0c;使得同一簇内的数据对象的相似性尽可能大&#xff0c;而不同簇中的数据对象的差异性也尽可能大。  这里主要是介绍两种比较经典的聚…

ArcGIS批量寻找图层要素中的空洞

空洞指的是图层中被要素包围所形成的没有被要素覆盖的地方&#xff0c;当图层要素数量非常庞大时&#xff0c;寻找这些空洞就不能一个一个的通过目测去寻找了&#xff0c;需要通过使用工具来实现这一目标。 一、【要素转线】工具 利用【要素转线】工具可以将空洞同图层要素处于…

[ LeetCode ] 题刷刷(Python)-第66题:加一

题目描述 给定一个由 整数 组成的 非空 数组所表示的非负整数&#xff0c;在该数的基础上加一。 最高位数字存放在数组的首位&#xff0c; 数组中每个元素只存储单个数字。 你可以假设除了整数 0 之外&#xff0c;这个整数不会以零开头。 示例 示例 1&#xff1a; 输入&#xf…