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

12380 举报网站建设做计算机网站

12380 举报网站建设,做计算机网站,北京前端哪个培训机构好,如何让百度快速收录新网站倍增 倍增算法是一种优化算法,通常用于某些需要高效计算指数幂的场景。它基于分治的思想,通过反复求平方来实现快速计算指数幂的目的。在实际应用中,倍增算法经常用于解决最近公共祖先问题、二分查找等。 1、快速幂详解 ksm核心代码 倍增就是…

倍增

倍增算法是一种优化算法,通常用于某些需要高效计算指数幂的场景。它基于分治的思想,通过反复求平方来实现快速计算指数幂的目的。在实际应用中,倍增算法经常用于解决最近公共祖先问题、二分查找等。

1、快速幂详解

ksm核心代码

在这里插入图片描述

倍增就是基于二进制的指数倍相乘,使得效率更高。任何一个数的幂都可以看作二进制来计算。

ll ksm(ll a,ll n){ll r=1;while(n!=0){if(n&1){r*=a;}a=a*a;n=n>>1;}return r;
}

简单应用:

  • 计算a^n mod m
  • 计算斐波那契数列第n项
  • 将线性变换重复n次

注:矩阵的乘法计算

2、链式前向星举例

2.1、图

关于图的定义方式:

struct Edge {int next; // 下一条边的编号int to;   // 这一条边的终点int w;    // 权值
} e[maxn];

一般的输入方式都是:u -> v w 边 边 权

ll tot, head[maxn];
void add(ll u, ll v, ll w) {++tot; // 加入一条新边的编号e[tot].next = head[u]; // 新的边插在原来的第一个位置,所以next指向原来的head[u]e[tot].w = w;e[tot].to = v; // 下一条边head[u] = tot; // 新的边成为第一条变了
}

代码案例:

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
using namespace std;
using ll = long long;
#define maxn 110001
struct Edge {int next; // 下一条边的编号int to;   // 这一条边的终点int w;    // 权值
} e[maxn];
ll tot, head[maxn];
void add(ll u, ll v, ll w) {++tot; // 加入一条新边的编号e[tot].next = head[u]; // 新的边插在原来的第一个位置,所以next指向原来的head[u]e[tot].w = w;e[tot].to = v; // 下一条边head[u] = tot; // 新的边成为第一条变了
}
int main() {IOS;// 添加边add(1, 2, 10);add(1, 3, 20);add(2, 4, 30);add(3, 4, 40);add(4, 5, 50);	// 打印图的邻接表for (int i = 1; i <= 5; ++i) {cout << "Vertex " << i << ": ";for (int j = head[i]; j != 0; j = e[j].next) {cout << "(" << e[j].to << ", " << e[j].w << ") ";}cout << endl;}return 0;
}

2.2、树

LCA问题

	int n;cin>>n;vector<vector<int>> graph(n+1);for(int i=1;i<n;i++){//n-1 条边int u,v;cin>>u>>v;graph[i].push_back(u);graph[i].push_back(v);//邻接矩阵}//倍增数组vector<array<int,21>> fa(n+1);//array<int,21> 固定的数组大小21vector<int> dep(n+1);//深度function<void(int,int)> dfs = [&](int x,int f){fa[x][0]=f;for(int i=1;i<=20;i++){fa[x][i]=fa[fa[x][i-1]][i-1];}//遍历数组for(const auto& tox:graph[x]){if(tox==f)continue;dep[tox]=dep[x]+1;dfs(tox,x);}};dfs(1,0);auto glca = [&](int x,int y){if(dep[x]<dep[y])swap(x,y);int d=dep[x]-dep[y];for(int i=20;i>=0;i--){if(d>>i & 1)x=fa[x][i];}if(x==y)return x;for(int i=20;i>=0;i--){if(fa[x][i] != fa[y][i]){x=fa[x][i];y=fa[y][i];}}return fa[x][0];};
http://www.yayakq.cn/news/278975/

相关文章:

  • Html5移动网站个人网站注册流程
  • 高埗镇仿做网站软件研发和开发的区别
  • 做企业网站的优势动态手机网站
  • 建行国际互联网网站wordpress 外贸 开发
  • 班级网站设计模板南昌为来创意网站建设公司
  • 校园网站制度建设嘉兴网站排名
  • 企业网站的网络营销专业做写生的网站
  • 学校网站建设栏目有哪些html网站地图在线生成
  • 河北建设厅网站首页郑州百姓网二手货车
  • 网上网站建设教程猎头公司一般怎么收费的
  • 做网站有什么市场风险dede安装好后是模板怎么变成做好的网站
  • 怎么做自己的外卖网站数码网站建设维护
  • 个人可以做微信小程序吗?20条优化措施
  • linux网站服务器搭建天元建设集团有限公司欠薪问题
  • 网站名称和域名不一致网站规划与建设书
  • 化工网站开发在线购物网站建设
  • 亦庄公司做网站公司名字大全20000个四个字
  • 网站搭建策略与方法有哪些方面企业网站硬件设计
  • 设计接单网站大全wordpress小工具放入用户中心
  • 江西网站设计电话做项目搭建网站 构建数据库
  • 大型网站维护费一年多少二级域名网站优化
  • 外贸网站建设的重要性宝塔反代wordpress
  • 深圳黑马品牌网站设计制作公司网站大概多少钱
  • 康定网站建设公司做淘宝必备网站
  • 餐饮门户网站源码网站开发大学
  • flash云网站产品网上推广的方法有哪些
  • 福建建设执业注册中心网站在线音乐网站 用什么做
  • 国家建设部官方网站投诉泉州自助建站
  • 快速的网站开发厦门seo网站管理
  • 一个服务器可以做多个网站吗会员视频网站建设