nbhkdz.com冰点文库

分治

时间:2012-12-01


例:求n(n是2的幂(n>=2))个元素中的最大元与最小元。

[分析]用分治法解决这个问题就是把集合a分成a1,a2两个子集,每个子集有n/2个元素,应用递归结构找出两个子集的最大元和最小元,比较得到的两个最大元和最小元即可得到整个集合a中的最大元和最小元。

[参考程序]
program fenzhi

;
const n=10;
type atype=array[1..n]of integer;
var max,min,I:integer;
a:atype;
procedure maxmin(r1,r2:integer;var max,min:integer);
var d,max1,min1,max2,min2:integer;
begin
if r2=r1+1 then
begin
if a[r2]>a[r1] then begin
max:=a[r2];
min:=a[r1];
end
else begin
min:=a[r2];
max:=a[r1];
end
end
else
begin
d:=(r1+r2)div 2;
maxmin(r1,d,max1,min1);
maxmin(d,r2,max2,min2);
if max1>max2 then max:=max1 else max:=max2;
if min1>min2 then min:=min2 else min:=min1;
end;
begin
writeln(‘input a:’);
for I:=1 to n do read(a[i]);
maxmin(1,n,max,min);
writeln(‘the max number is:’,max,’min number is:’,min);
end.

算法设计与分析- 分治策略实验

算法设计与分析- 分治策略实验_数学_自然科学_专业资料。实验 3 分治策略实验实验内容 1. 二分搜索。分别使用非递归算法和递归算法实现二分搜索。【输入:一个 一...

从《Cash》谈一类分治算法的应用

从《Cash》谈一类分治算法的应用_电脑基础知识_IT/计算机_专业资料。陈丹琦2008年信息学国家集训队作业 2008 年信息学国家集训队作业 雅礼中学 陈丹琦 从《Cash》谈...

分治算法试题

分治算法试题_理学_高等教育_教育专区。分治算法当我们求解某些问题时,由于这些问题要处理的数据相当多,或求解过程相当复杂,使得直接求解法 在时间上相当长,或者根本...

分治算法实验报告

《算法设计与分析》实验报告 实验 1 分治算法 姓名张成辉 学号 1307300123 班级计科 132 实验日期 2015.1.13 实验地点学院 302 一、实验目的 1、掌握分治算法的...

分治法求最大最小值

一. 实验目的及实验环境 实验目的:加深对分治算法原理及实现过程的理解。 实验环境:VC++6.0 二. 实验内容 用分治法求数组中最大元素和最小元素。 三.方案设计...

分治法解最接近点对问题

算法分析与设计实验报告 2014-2015 第一学期 实验一:用分治法解最接近点对问题 指导教师:cccc 实验时间:2014 年 10 月 28 日 实验地点:计算中心二楼 班级: ...

分治法的应用

分治法的应用_IT/计算机_专业资料。分治法的应用分治法是建基于多项分支递归的一种很重要的算法范式。字面上的解释是 “分而治之” ,就是把一个复杂的问题分成...

贪心算法、分治算法、动态规划算法间的比较.doc

贪心算法、分治算法、动态规划算法间的比较.doc_数学_自然科学_专业资料。贪心算法、分治算法、动态规划算法间的比较 题目:贪心算法、分治算法、动态规划算法间的比较...

基于分治法的快速排序

实验2. 基于分治法的快速排序算法 实验内容本实验要求基于算法设计与分析的一般过程(即待求解问题的描述、算法设计、算法 描述、算法正确性证明、算法分析、算法实现...

算法分析——分治法

算法分析——分治法_IT/计算机_专业资料。分治算法小组的汇报内容: 小组的汇报内容:一、分治算法的基本概念………第 2 页 分治算法的基本概念………第 基本概念...