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

鱼爪网商城网站如何建设游戏网站开发有限公司

鱼爪网商城网站如何建设,游戏网站开发有限公司,长沙seo研究中心,广州网站建设专业乐云seo#x1f38a;【数据结构与算法】专题正在持续更新中#xff0c;各种数据结构的创建原理与运用✨#xff0c;经典算法的解析✨都在这儿#xff0c;欢迎大家前往订阅本专题#xff0c;获取更多详细信息哦#x1f38f;#x1f38f;#x1f38f; #x1fa94;本系列专栏 -… 【数据结构与算法】专题正在持续更新中各种数据结构的创建原理与运用✨经典算法的解析✨都在这儿欢迎大家前往订阅本专题获取更多详细信息哦 本系列专栏 -  数据结构与算法_勾栏听曲_0 欢迎大家    点赞  评论  收藏⭐️ 个人主页 - 勾栏听曲_0的博客 希望本文能对你有所帮助如有不足请指正共同进步吧 一个人无论在祈祷什么他祈祷的都只不过是一个奇迹。所有祈祷文无非都是一个意思:“伟大的上帝啊请使二乘二不等于四吧!” 分治法 算法思想 时间效率分析 合并排序 分治法 算法思想 分治法可能是最著名的通用算法设计技术了。虽然它的名气可能和它那好记的名字有关但它的确是当之无愧的:很多非常有效的算法实际上就是这个通用算法的特殊实现。其实分治法是按照以下方案工作的。 (1)将一个问题划分为同一类型的若干子问题子问题最好规模相同。         (2)对这些子问题求解(一般使用递归方法但在问题规模足够小时有时也会利用另一个算法)。         (3)有必要的话合并这些子问题的解以得到原始问题的答案。 分治法的流程可以参见下图该图描述的是将一个问题划分为两个较小子问题的例子也是最常见的情况(至少那些设计运行在单CPU机器上的分治算法是这样的)。 时间效率分析  在分治法最典型的运用中问题规模为n的实例被划分为两个规模为n/2的实例。更一般的情况下一个规模为n的实例可以划分为b个规模为n/b的实例其中α个实例需要求解(这里a和b是常量a≥1b1)。为了简化分析我们假设n是b的幂对于算法的运行时间T(n)我们有下列递推式: T(n) aT(n / b) f(n) 其中f(n)是一个函数表示将问题分解为小问题和将结果合并起来所消耗的时间(对于求和的例子来说a b 2f(n) 1)。上述递推式被称为通用分治递推式(generaldivide-and-conquer recurrence)。显然T(n)的增长次数取决于常量a和b的值以及函数f(n)的增长次数。在分析许多分治算法的效率时可以应用下列定理来大大简化我们的工作。 主定理        如果在递推式(5.1)中 f(n)e e(n*)其中d≥0那么 其中当a  时该问题的时间复杂度为n的d次方 当a  时该问题的时间复杂度为n的d次方乘一个对数级 当a  时该问题的时间复杂度为n的log b为底a次方 合并排序 合并排序是成功应用分治技术的一个完美例子。对于一个需要排序的数组A[0..n -1],合并排序把它一分为二A[0..[n / 2| - 1]和A[ [n / 2 ]..n-1]并对每个子数组递归排序然后把这两个排好序的子数组合并为一个有序数组。 下图演示的是用合并排序算法对数列8,3,2,9,7,1,5,4进行排序的操作过程。   接下来通过视频演示来了解合并排序算法对数列8,3,2,9,7,1,5,4进行排序的操作过程。 合并排序_分治法代码实现 #include stdio.hvoid merge(int arr[], int l, int m, int r) {int i, j, k;int n1 m - l 1;int n2 r - m;/* 创建临时数组 */int L[n1], R[n2];/* 复制数据到临时数组 arrays L[] 和 R[] */for (i 0; i n1; i)L[i] arr[l i];for (j 0; j n2; j)R[j] arr[m 1 j];/* 归并临时数组到 arr[l..r]*/i 0; // 初始化第一个子数组的索引j 0; // 初始化第二个子数组的索引k l; // 初始归并子数组的索引while (i n1 j n2) {if (L[i] R[j]) {arr[k] L[i];i;}else {arr[k] R[j];j;}k;}/* 复制 L[] 的保留元素 */while (i n1) {arr[k] L[i];i;k;}/* 复制 R[] 的保留元素 */while (j n2) {arr[k] R[j];j;k;} }/* l 为左侧索引r 为右侧索引 */ void mergeSort(int arr[], int l, int r) {if (l r) {// 求中间位置防止 (lr) 的和超过 int 类型最大值int m l(r-l)/2;// 递归排序左半部分mergeSort(arr, l, m);// 递归排序右半部分mergeSort(arr, m1, r);// 合并merge(arr, l, m, r);} }
http://www.dnsts.com.cn/news/45875.html

相关文章:

  • 多语言的网站太原网页设计公司
  • 专门做搜索种子的网站有哪些asp网站源码说明
  • 给人做网站的网络搞钱路子
  • 响水哪家专业做网站陕西的建设厅官方网站
  • 网站续费一般多少钱深圳平湖做网站
  • 室内设计师网站十大网站深圳网站制作比较好公司
  • 网站名称备案最轻快的wordpress主題
  • 怎么快速推广appseo自助建站平台
  • 网站托管方式wordpress标签页模板
  • 做网站客户要提供什么wordpress 挂马 清除
  • 网站seo外包价格网页制作与网站建设填空题
  • 微网站 源码 免费网站开发客户挖掘
  • 台州网站建设蓝渊建站宝盒视频
  • 西安网站品牌建设蚂蚁加速器
  • 景县网址建站vs2012建设网站
  • 网站分类导航代码网站建设junke100
  • 如何利用站群做网站网络营销培训哪里好
  • 有哪个网站可以学做吃的网页和移动端界面设计
  • 网站后台基本功能长沙广告公司排行榜
  • 常州网站建设公司做网站需要人在看吗
  • 网站关键词优化实验结果分析外贸公司有哪些类型
  • 宝塔做的网站能不能访问深圳市商事主体登记注册
  • 天津网站排名html表白网页制作源码
  • 手机网站端域名怎样做解析去除wordpress后台登录logo
  • 详情页生成器天津短视频seo
  • 温州高端网站定制搜索关键词排名提升
  • 苏州网站建设建站网wordpress用微博sdk
  • lol视频网站模板爱站工具包下载
  • 百度网盘怎样做网站Wordpress教程推荐
  • 网站建设的基本步骤福州哪里做网站