分治算法(Divide Conquer)

文章目录

    • 1. 分治算法思想
    • 2. 应用举例
      • 2.1 逆序度
    • 3. 分治思想处理海量数据

1. 分治算法思想

  • 分治算法的核心思想就是,分而治之,将原问题划分成n个规模较小,并且结构与原问题相似的子问题,递归地解决这些子问题,然后再合并其结果,就得到原问题的解。
  • 分治算法一般都比较适合用递归来实现。分治算法的递归实现中,每一层递归都会涉及这样三个操作:
    -1- 分解:将原问题分解成一系列子问题;
    -2- 解决:递归地求解各个子问题,若子问题足够小,则直接求解;
    -3- 合并:将子问题的结果合并成原问题。

分治算法能解决的问题,一般需要满足下面这几个条件:

  • 原问题与子问题具有相同的模式
  • 子问题可以独立求解子问题之间没有相关性,这一点是分治算法跟动态规划的明显区别;
  • 具有分解终止条件,也就是说,当问题足够小时,可以直接求解;
  • 可以将子问题合并成原问题,这个合并操作的复杂度不能太高。

2. 应用举例

2.1 逆序度

假如需要从小到大排序,大的数在小的数前面则记逆序数+1
在这里插入图片描述

  • 暴力的方法:分别对每个数,看后面有几个比它小的,双重循环,复杂度O(n2
  • 归并排序法
    将原序列分成A1,A2两个序列,分别计算它两的逆序度K1,K2,再计算A1,A2之间的逆序度K3,原序列逆序度就是 K1+K2+K3
    在这里插入图片描述
/*** @description: 分治法求逆序数(归并排序法)* @author: michael ming* @date: 2019/7/3 23:27* @modified by: */
#include <iostream>
class ReverseOrderCount
{int sum;void divide(int *a, int left, int right){if(left >= right)return;int mid = (left+right)/2;divide(a,left,mid);divide(a,mid+1,right);merge(a,left,mid,right);}void merge(int *a, int left, int mid, int right){int i = left, j = mid+1, len = right-left+1, idx = 0;int *temp = new int [len];while(i <= mid && j <= right){if(a[i] <= a[j])temp[idx++] = a[i++];else{sum += mid-i+1;//左边i后面的都比a[j]大temp[idx++] = a[j++];}}while(i <= mid)//剩余的半边temp[idx++] = a[i++];while(j <= right)//剩余的半边temp[idx++] = a[j++];for(idx = 0; idx < len; ++idx){a[left++]= temp[idx];  //把有序的临时数组写入原来数组的起始位置}delete [] temp;  //释放空间temp = NULL;  //指针置空}
public:int count(int *a, int n){sum = 0;divide(a,0,n-1);return sum;}
};int main()
{ReverseOrderCount roc;int arr[6] = {2,4,3,1,5,6};std::cout << "arr数组的逆序数是:" << roc.count(arr,6);return 0;
}

在这里插入图片描述

  • 练习题 http://poj.org/problem?id=2299
    Accepted代码如下
    https://github.com/hitskyer/course/blob/master/c/chenmingming/algorithm/POJ/poj2299_B.cpp

3. 分治思想处理海量数据

比如,给10GB的订单文件按照金额排序,看似是一个简单的排序问题,但是因为数据量大,有10GB,机器的内存可能只有2、3GB这样子,无法一次性加载到内存,也就无法通过单纯地使用快排、归并等基础算法来解决。

  • 利用分治思想。将海量的数据集合划分为n个小的数据集合,每个小的数据集合单独加载到内存来解决,然后再将小数据集合并成大数据集合。
  • 利用分治,不仅仅能克服内存的限制,还能利用多线程或者多机处理加快处理的速度。海量的数据利用集群并行处理是大势所趋。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/480143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

史上最全Java多线程面试60题,含答案大赠送!

【BAT必考系列&#xff01;多线程60题】 多线程有什么用&#xff1f; 线程和进程的区别是什么&#xff1f; ava实现线程有哪几种方式&#xff1f; 启动线程方法start&#xff08;&#xff09;和run&#xff08;&#xff09;有什么区别&#xff1f; 怎么终止一个线程&#…

论文浅尝 | Interaction Embeddings for Prediction and Explanation

本文是我们与苏黎世大学合作的工作&#xff0c;将发表于WSDM2019&#xff0c;这篇工作在知识图谱的表示学习中考虑了实体和关系的交叉交互&#xff0c;并且从预测准确性和可解释性两个方面评估了表示学习结果的好坏。给定知识图谱和一个要预测的三元组的头实体和关系&#xff0…

商汤科技-数据运维工程师-提前批笔试题目汇总

2019年8月19日 问答题1&#xff1a;缺失值数据预处理有哪些方法&#xff1f;https://juejin.im/post/5b5c4e6c6fb9a04f90791e0c 处理缺失值的方法如下&#xff1a;删除记录&#xff0c;数据填补和不处理。主要以数据填补为主。 1 删除记录&#xff1a;该种方法在样本数据量十分…

秋招视频攻略!13个offer,8家SSP的Q神谈算法岗秋招技巧

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术大家还记得几个月前卖萌屋Q神推送的那期《13个offer&#xff0c;8家SSP&#xff0c;谈谈我的秋招经验》吗&#xff1f;据说Q神掌握了影分身的话&#xff0c;一毕业就能年薪600万&#xff0c;咳咳。。。ps&…

分治应用--最近点对问题 POJ 3714

文章目录1. 问题描述2. 解题思路3. 实现代码4. POJ 37141. 问题描述 二维平面上有n个点&#xff0c;如何快速计算出两个距离最近的点对&#xff1f; 2. 解题思路 暴力做法是&#xff0c;每个点与其他点去计算距离&#xff0c;取最小的出来&#xff0c;复杂度O(n2)采用分治算…

Java多线程系列(十):源码剖析AQS的实现原理

在并发编程领域&#xff0c;AQS号称是并发同步组件的基石&#xff0c;很多并发同步组件都是基于AQS实现&#xff0c;所以想掌握好高并发编程&#xff0c;你需要掌握好AQS。 本篇主要通过对AQS的实现原理、数据模型、资源共享方式、获取锁的过程&#xff0c;让你对AQS的整体设计…

玩转二算法课的笔记-第一章

1 问题&#xff1a;对一组数据进行排序 回答&#xff1a;快速排序算法o(NLOGN)&#xff0c;错误。 关键词&#xff1a;思考 应该问面试官&#xff0c;这组数据有什么样的特征&#xff1f; 比如;有没有可能包含大量重复的元素&#xff1f; 如果有这个可能的话&#xff0c;三路快…

微软亚洲研究院NLC组招聘实习生!与一线研究员共探NLP前沿与落地!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术MSRA-NLC组招人啦&#xff01;微软亚洲研究院&#xff08;MSRA&#xff09;自然语言计算组&#xff08;NLC&#xff09;招收长期实习生一名&#xff0c;与一线研究员共同进行自然语言处理领域的科研项目和落地…

分治应用--万里挑一 找假硬币

文章目录1. 问题描述2. 解题思路3. 代码实现1. 问题描述 n 个硬币中有1枚是假币&#xff0c;真假币唯一的区别是假币重量轻&#xff0c;如何快速找出假币 2. 解题思路 暴力做法&#xff0c;一个一个的称重&#xff0c;O&#xff08;n&#xff09;复杂度分治思路 将硬币等分…

Java多线程与并发系列从0到1全部合集,强烈建议收藏!

在过去的时间中&#xff0c;我写过Java多线程与并发的整个系列。 为了方便大家的阅读&#xff0c;也为了让知识更系统化&#xff0c;这里我单独把Java多线程与并发的整个系列一并罗列于此&#xff0c;希望对有用的人有用&#xff0c;也希望能帮助到更多的人。 以下为整个目录&a…

论文浅尝 | 基于图注意力的常识对话生成

OpenKG 祝各位读者新春快乐&#xff0c;猪年吉祥&#xff01;来源&#xff1a;IJCAI 2018.论文下载地址&#xff1a;https://www.ijcai.org/proceedings/2018/0643.pdf项目源码地址&#xff1a;https://github.com/tuxchow/ccm动机在以前的工作中&#xff0c;对话生成的信息源是…

Facebook、阿里等大佬现身说法,NLP是否被高估了?

NLP (自然语言处理)&#xff0c;利用计算机对人类的语言文字进行处理。由于语言文字是人类交流沟通的最基本方式&#xff0c;因此 NLP 也是最典型的 AI 领域之一。NLP 被誉为“人工智能皇冠上的明珠”。这话也许没错&#xff0c;但听起来难免空洞。所以我去实际问了3位从事 NLP…

玩转算法面试-第二章

1 时间复杂度分析 正常处理的数据规模&#xff0c;为了保险起见&#xff0c;可将将上面的数在除以10&#xff0c;防止电脑假死。 空间复杂度分析&#xff1a; 注意问题&#xff1a;递归调用是有空间代价的 3 常见的复杂度分析 翻转的代码&#xff1a; 选择排序的方法&a…

论文笔记(Attentive Recurrent Social Recommendation)

注意力循环社交推荐 原文链接&#xff1a;Attentive Recurrent Social Recommendation, SIGIR’18 原理&#xff1a;将用户的朋友和历史交互项按时间划分&#xff0c;用注意力机制整合各个时段的朋友影响和交互项影响后输入LSTM来学习动态用户向量&#xff0c;动态用户向量与动…

回溯算法(Backtracking Algorithm)之八皇后问题

文章目录1. 回溯算法思想2. 算法应用2.1 八皇后问题1. 回溯算法思想 前面讲过贪心算法并不能保证得到最优解&#xff0c;那怎么得到最优解呢&#xff1f; 回溯思想&#xff0c;有点类似枚举搜索。枚举所有的解&#xff0c;找到满足期望的解。为了有规律地枚举所有可能的解&am…

最全Java锁详解:独享锁/共享锁+公平锁/非公平锁+乐观锁/悲观锁

在Java并发场景中&#xff0c;会涉及到各种各样的锁&#xff0c;比如&#xff1a;高并发编程系列&#xff1a;4种常用Java线程锁的特点&#xff0c;性能比较、使用场景&#xff0c;这些锁有对应的种类&#xff1a;公平锁&#xff0c;乐观锁&#xff0c;悲观锁等等&#xff0c;这…

论文浅尝 | Generative QA: Learning to Answer the Whole Question

链接: https://openreview.net/forum?idBkx0RjA9tX传统的机器阅读理解的模型都是给定 context 和 question, 找出最有可能回答该 question 的 answer&#xff0c;用概率表示为 p(a|q,c)&#xff0c;这其实是一个判别模型。判别模型在大多数任务上可以取得比生成模型更好的准确…

打破BERT天花板:11种花式炼丹术刷爆NLP分类SOTA!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | JayLou娄杰编 | 小轶在2020这个时间节点&#xff0c;对于NLP分类任务&#xff0c;我们的关注重点早已不再是如何构造模型、拘泥于分类模型长什么样子了。如同CV领域当前的重点一样&#xff0c;我们更应该…

论文笔记(A Neural Influence Diffusion Model for Social Recommendation)

神经影响传播模型为了社交推荐 原文链接&#xff1a;A Neural Influence Diffusion Model for Social Recommendation, SIGIR’19 原理&#xff1a;社交网络上应用GNN提取朋友对用户的影响候选项对用户历史交互项的注意力影响用户向量&#xff0c;用户向量和项向量的内积预测评…

玩转算法面试-第三章

数组中常见的问题 排序&#xff1a; 选择排序&#xff1b;插入排序&#xff1b;归并排序&#xff1b;快速排序 查找&#xff1a;二分查找法 数据结构&#xff1a;栈&#xff1b;队列&#xff1b;堆 … 二分查找法&#xff1a; 1964年提出&#xff0c;没有bug的二分查找法是在1…