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

中国建设协会网站网络营销的职能是什么

中国建设协会网站,网络营销的职能是什么,深圳商业网站建设系统,北京seo加盟✨博主#xff1a;命运之光 ✨专栏#xff1a;算法基础学习 目录 ✨最小生成树 #x1f353;朴素Prim #x1f353;Kruskal算法 ✨二分图 #x1f353;匈牙利算法 ✨质数 #x1f353;#xff08;1#xff09;质数的判定——试除法 #x1f353;#xff08;2命运之光 ✨专栏算法基础学习 目录 ✨最小生成树  朴素Prim Kruskal算法 ✨二分图 匈牙利算法 ✨质数 1质数的判定——试除法 2分解质因数——试除法 ✨约数 1试除法求一个数的所有约数 2约数个数 3约数之和 4欧几里得算法辗转相除法 前言算法学习笔记记录日常分享需要的看哈O(∩_∩)O感谢大家的支持 ✨最小生成树  朴素Prim 朴素版prim算法 时间复杂度是 O(n2m)O(n2m), nn 表示点数mm 表示边数 int n; // n表示点数 int g[N][N]; // 邻接矩阵存储所有边 int dist[N]; // 存储其他点到当前最小生成树的距离 bool st[N]; // 存储每个点是否已经在生成树中 // 如果图不连通则返回INF(值是0x3f3f3f3f), 否则返回最小生成树的树边权重之和 int prim() {memset(dist, 0x3f, sizeof dist);int res 0;for (int i 0; i n; i ){int t -1;for (int j 1; j n; j )if (!st[j] (t -1 || dist[t] dist[j]))t j;if (i dist[t] INF) return INF;if (i) res dist[t];st[t] true;for (int j 1; j n; j ) dist[j] min(dist[j], g[t][j]);}return res; } Kruskal算法 Kruskal算法 时间复杂度是 O(mlogm)O(mlogm), nn 表示点数mm 表示边数 int n, m; // n是点数m是边数 int p[N]; // 并查集的父节点数组 struct Edge // 存储边 {int a, b, w;bool operator (const Edge W)const{return w W.w;} }edges[M]; int find(int x) // 并查集核心操作 {if (p[x] ! x) p[x] find(p[x]);return p[x]; } int kruskal() {sort(edges, edges m);for (int i 1; i n; i ) p[i] i; // 初始化并查集int res 0, cnt 0;for (int i 0; i m; i ){int a edges[i].a, b edges[i].b, w edges[i].w;a find(a), b find(b);if (a ! b) // 如果两个连通块不连通则将这两个连通块合并{p[a] b;res w;cnt ;}}if (cnt n - 1) return INF;return res; } ✨二分图 染色法 判断一个图是不是二分图 二分图可以把所有点分成两边使所有边在集合之间集合内部没有边。 二分图当且仅当图中不含奇数环 染色法判别二分图 时间复杂度是 O(nm)O(nm), nn 表示点数mm 表示边数 int n; // n表示点数 int h[N], e[M], ne[M], idx; // 邻接表存储图 int color[N]; // 表示每个点的颜色-1表示未染色0表示白色1表示黑色 // 参数u表示当前节点c表示当前点的颜色 bool dfs(int u, int c) {color[u] c;for (int i h[u]; i ! -1; i ne[i]){int j e[i];if (color[j] -1){if (!dfs(j, !c)) return false;}else if (color[j] c) return false;}return true; } bool check() {memset(color, -1, sizeof color);bool flag true;for (int i 1; i n; i )if (color[i] -1)if (!dfs(i, 0)){flag false;break;}return flag; } 匈牙利算法 匈牙利算法 时间复杂度是 O(nm)O(nm), nn 表示点数mm 表示边数 int n1, n2; // n1表示第一个集合中的点数n2表示第二个集合中的点数 int h[N], e[M], ne[M], idx; // 邻接表存储所有边匈牙利算法中只会用到从第一个集合指向第二个集合的边所以这里只用存一个方向的边 int match[N]; // 存储第二个集合中的每个点当前匹配的第一个集合中的点是哪个 bool st[N]; // 表示第二个集合中的每个点是否已经被遍历过 bool find(int x) {for (int i h[x]; i ! -1; i ne[i]){int j e[i];if (!st[j]){st[j] true;if (match[j] 0 || find(match[j])){match[j] x;return true;}}}return false; } // 求最大匹配数依次枚举第一个集合中的每个点能否匹配第二个集合中的点 int res 0; for (int i 1; i n1; i ) {memset(st, false, sizeof st);if (find(i)) res ; } ✨质数 所有大于1的自然数所有1的数既不是质数也不是合数 定义在大于1的整数中如果只包含1和本身这两个约数就被称为质数或者叫素数 1质数的判定——试除法 质数的一个重要性质如果d能整除n,显然n除d也能整除n 故发现n的所有的约数都是成对出现的d与n/d都成成对出现的 所以枚举时可以只枚举每一对当中较小的那一个枚举 试除法判定质数 bool is_prime(int x) {if (x 2) return false;for (int i 2; i x / i; i )if (x % i 0)return false;return true; } 2分解质因数——试除法 从小到大枚举所有数 试除法分解质因数 void divide(int x) {for (int i 2; i x / i; i )if (x % i 0){int s 0;while (x % i 0) x / i, s ;cout i s endl;}if (x 1) cout x 1 endl;cout endl; } 筛 罗列出每个数依次删除每个数的倍数剩下的数就是质数可以对此进行优化可以不删每一个数的倍数 可以只删质数的倍数这样就不用重复删。 质数定理 优化完的筛法埃氏筛法 朴素筛法求素数 int primes[N], cnt; // primes[]存储所有素数 bool st[N]; // st[x]存储x是否被筛掉 void get_primes(int n) {for (int i 2; i n; i ){if (st[i]) continue;primes[cnt ] i;for (int j i i; j n; j i)st[j] true;} } 线性筛法 把每一个合数用它的某个质因子筛掉 每个数都会被其最小质因子筛掉而且每个数只有一个最小质因子故每个数只会被筛一次 线性筛法求素数 int primes[N], cnt; // primes[]存储所有素数 bool st[N]; // st[x]存储x是否被筛掉 void get_primes(int n) {for (int i 2; i n; i ){if (!st[i]) primes[cnt ] i;for (int j 0; primes[j] n / i; j ){st[primes[j] * i] true;if (i % primes[j] 0) break;}} } ✨约数 约数 1试除法求一个数的所有约数 试除法求所有约数 vectorint get_divisors(int x) {vectorint res;for (int i 1; i x / i; i )if (x % i 0){res.push_back(i);if (i ! x / i) res.push_back(x / i);}sort(res.begin(), res.end());return res; } 2约数个数 3约数之和 约数个数和约数之和 如果 N p1^c1 * p2^c2 * ... *pk^ck 约数个数 (c1 1) * (c2 1) * ... * (ck 1) 约数之和 (p1^0 p1^1 ... p1^c1) * ... * (pk^0 pk^1 ... pk^ck) 4欧几里得算法辗转相除法 欧几里得算法 int gcd(int a, int b) {return b ? gcd(b, a % b) : a; // 表达式1?表达式2:表达式3 } //它的意思是如果表达式1成立则输出表达式2的值否则输出表达式3的值 补充小知识 两个数的积等于它们最大公约数和它们最小公倍数的 积。公式表示为 a×bgcd(a,b)×lcm(a,b) 最小公倍数与最大公约数模板
http://www.dnsts.com.cn/news/224687.html

相关文章:

  • 网站建设 招标资质要求东西湖区建设局网站
  • 郑州电商网站设计php sqlite 做网站
  • 开发网站的流程细节百度allin 人工智能
  • 口碑最好的购物网站平台丰台做网站公司
  • 做公司网站排名怎么制作纯文字图片
  • 国内可以使用的自己建站网站出现用户名密码提示
  • 驾校网站建设河南省建设工程人力资源
  • 广西住房和城乡建设厅培训中心官方网站珠海建设工程交易中心网站
  • 建网站不想用怎样撤销crm系统登录
  • 网站如何进行网络推广广州海珠区繁华吗
  • 国内做化妆刷的比较好的网站wordpress 金融 模板
  • 承德网站制作与建设什么网站做跨境电子商务
  • wordpress主题 ux电脑优化大师下载安装
  • 公司建立网站的意义网站流量统计工具有哪些
  • 房山网站建设wordpress连接不了ftp
  • 常德网站建设wynet123福州公司建设网站
  • seo推广软件费用seo网站分析工具
  • 找装修公司上什么网站平面设计培训网站大全
  • 外贸网站建设推广公司哪里有免费建设网站
  • 网站如何做双语言如何建设网站知乎
  • 电商模板网站大宗商品电子交易平台
  • 炫酷的动画网站中国纪检监察报订阅
  • 国家住房部和城乡建设部 网站首页大庆建设公司网站
  • 双语网站系统手机网站和app的区别
  • 成都网站优化多少钱咸阳商城网站开发设计
  • 普陀微信网站建设wordpress 文章 格式
  • 大庆+网站建设东莞网站系统找哪里
  • 临漳+网站建设重庆网站建设电话
  • 阿里巴巴网站建设与维护虚拟空间软件下载
  • 企业内部的网站系统什么是网络设计图