第 五 章 减治法
5-第五章 减治法

2.比较v和 A[x]
确定查找范围
5.6.3 二叉查找树的查找和插入
• 二叉查找树:左子树的值小于根顶点,右 子树大于根顶点。
小结
5.4 生成组台对象的算法
• 组合问题 1、计数 2、结构
组合问题
5.4.1 生成排列
用减一思想生成{1,2,…,n}所有排列。
Johnson-trotter算法
• 字典序---增序排队
5.4.2 生成子集
1、挤压序: 所 2、是否存在—种生成比特串的最小变化算法,使得每
一个比特串和它的直接前趋之间仅仅相差一 个比特 位。
n / 2 ,它要求找出这样一个元素,该元素比列表中的—半元素大,又比另—半元素
小。这个中间的值被称为中值,它在数理统计中是—个非常重要的量。
• 类似快速排序的分区做法
• 例
15 15
效率分析: 1)平均效率 2)最差效率
5.6.2 插值查找
插值查找用于有序数组,“插值”代替了折 半查找中的中间值 1.计算
• 最坏输入是一个严格递减的数组,这种输 入的比较次数是
• 最好的情况下(升序),在外部循环的每 次送代中,比较操作只执行一次
• 平均
5.2深度优先查找和广度忧先查找
• 什么叫图的遍历 从图的任意点出发沿着一些边访问图中的 所有顶点,且使每个顶点仅被访问一次,这就 叫图的遍历. • 我们来看一下图的遍历的两种方法: 1.深度优先搜索 2.广度优先搜索
第一种算法是深度优先查找的一个简单应用:执行一次DFS遍 历,并记住顶点变成死端(即退出遍历栈)的顺序。将该次序反过来 就得到了拓扑排序的一个解。
第二种算法基于减(减一)治技术的一个直 接实现:不断地做这样—件事,在余下的有向 图中求出一个源,它是一个没有输入边的顶点, 然后把它和所有从它出发的边都删除。
算法设计与分析部分算法伪代码

第三章 蛮力法1.选择排序SelectionSort(A[0..n-1])for i=0 to n-2 domin=ifor j=i+1 to n-1 doif A[j]<A[min]min=jswap A[i] and A[min]2.冒泡排序BubbleSort(A[0..n-1])// 输入:数组A,数组中的元素属于某偏序集// 输出:按升序排列的数组Afor i=0 to n-2 dofor j=0 to n-2-i doif A[j+1]<A[j] swap A[j] and A[j+1]3.改进的冒泡算法ALGORITHM BubbleSortImproved( A[0,…,n –1] )// 冒泡排序算法的改进// 输入:数组A,数组中的元素属于某偏序集// 输出:按升序排列的数组Afor i ← 0 to n – 2 doflag ← Truefor j ← 0 to n – 2 – i doif A[j+1] < A[j]swap(A[j], A[j+1])flag ← False// 如果在某一轮的比较中没有交换,则flag为True,算法结束returnif flag = True4. 顺序查找算法算法 SwquentialSearch2(A[0...n],k)//顺序查找算法的实现,它用了查找键来作限位器//输入:一个n个元素的数组A和一个查找键K//输出:第一个值等于K的元素的位置,如果找不到这样的元素就返回 -1A[n]<--ki<--0while A[i]!=K doi<--i+1if i<n return iElse return -15. 蛮力字符串匹配算法 BruteForceStringMatch(T[0...n-1],P[0...m-1])//该算法实现了蛮力字符串匹配代表一段文本//输入:一个n个字符的数组T[0...n-1]// 一个m个字符的数组P[0..m-1]代表一个模式//输出:如果查找成功的话,返回文本的第一个匹配字串中第一个字符的位置, // 否则返回-1For i<--0 to n-m doj<--0While j<m and P[j]=T[i+j]doj<--i+1If j=m return ireturn -1合并排序最差Θ(nlog2n)快速排序最优Θ(nlog2n)最差Θ(n2)平均Θ(1.38nlog2n)选择排序 Θ(n2)冒泡排序 Θ(n2)插入排序最差Θ(n2)最优 Θ(n)平均 Θ(n2)第四章 分治法合并排序算法 MergeSort(A[0..n-1] )排序 // 递归调用mergesort来对数组 A[0...n-1]// 输入:一个可排序数组A[0..n-1]// 输出:非降序排列的数组A[0..n-1]if n > 1n/2 -1]copy A[0.. n/2 -1] to B[0..n/2 -1]copy A[ n/2 ..n-1] to C[0..MergeSort( B )MergeSort( C )Merge( B,C,A )两个数组合并的算法算法 Merge(B[0..p-1],C[0..q-1],A[0..p+q-1])//将两个有序数组合并成一个有序的数组和C[0...q-1]//输入:两个有序数组B[0...p-1]//输出:A[0..p+q-1]中已经有序存放了B和C中的元素 i=0,j=0,k=0;while i<p and j<q do≤C[j]if B[i]A[k]=B[i], i=i+1elseA[k]=C[j], j=j+1k=k+1if i=pcopy C[j..q-1] to A[k..p+q-1]elsecopy B[i..p-1] to A[0..p+q-1]快速排序算法QuickSort(A[l..r])// 使用快速排序法对序列或者子序列排序或者序列本身A[0..n-1]// 输入:子序列A[l..r]// 输出:非递减序列Aif l < rs ← Partition( A[l..r] )QuickSort( A[l..s-1] )QuickSort( A[s+1..r] )//s是中轴元素/基准点,是数组分区位置的标志实现分区的算法Partition( A[l..r] )// 输入:子数组A[l..r]// 输出:分裂点/基准点pivot的位置p ← A[l]i ← l; j ← r+1repeat≥ prepeat i ←i + 1until A[i]≤ prepeat j ← j – 1 until A[j]swap( A[i], A[j] )≥ juntil iswap( A[i], A[j] )swap( A[l], A[j] )return j折半查找BinarySearch( A[0..n-1], k )// 输入:已排序大小为n的序列A,待搜索对象k// 输出:如果搜索成功,则返回k的位置,否则返回-1 l=0,r=n-1;While l≤rmid= (l+r)/2if k = A[mid] return midelse if k < A[mid] r=m-1else l=m+1return -1Strassen矩阵Strassen方法M1=A11(B12-B22)M2=(A11+A12)B22M3=(A21+A22)B11M4=A22(B21-B11)M5=(A11+A22)(B11+B22)M6=(A12-A22)(B21+B22)M7=(A11-A21)(B11+B12)第五章 减治法插入排序ALGORITHM InsertionSort( A[0..n-1] )// 对给定序列进行直接插入排序// 输入:大小为n的无序序列A// 输出:按非递减排列的序列Afor i ← 1 to n-1 dotemp ← A[i]j ← i-1while j ≥ 0 and A[j] > temp doA[j+1] ← A[j]j ← j –1A[j+1] ←temp深度优先查找算法 BFS(G)//实现给定图的深度优先查找遍历//输入:图G=<V,E>//输出:图G的顶点,按照被DFS遍历第一次访问到的先后次序,用连续的整数标记,将V中的每个顶点标记为0,表示还“未访问”count =0//记录这是第几个访问的节点标记为 unvisitedmark each vertex with 0//∈ V dofor each vertex vif v is marked with 0dfs(v)dfs(v)//递归访问所有和v相连接的未访问顶点,然后按照全局变量count的值//根据遇到它们的先后顺序,给它们附上相应的数字count = count + 1mark v with countv dofor each vertexw adjacent toif w is marked with 0dfs(w)广度优先BFS(G)/实现给定图的深度优先查找遍历//输入:图G=<V,E>//输出:图G的顶点,按照被BFS遍历第一次访问到的先后次序,用连续的整数标记,将V中的每个顶点标记为0,表示还“未访问”count =0mark each vertex with 0for each vertex v∈ V dobfs(v)bfs(v)//递归访问所有和v相连接的未访问顶点,然后按照全局变量count的值//根据遇到它们的先后顺序,给它们附上相应的数字count = count + 1mark v with countinitialize queue with vwhile queue is not empty doa = front of queuefor each vertex w adjacent to a doif w is marked with 0count = count + 1mark w with countadd w to the end of the queueremove a from the front of the queue拓扑排序第六章 变治法Gauss消去法GaussElimination(A[1..n], b[1..n])// 输入:系数矩阵A及常数项 b// 输出:方程组的增广矩阵等价的上三角矩阵for i=1 to n doA[i][n+1] =b[i]for j= i+1 to n dofor k = i to n+1 do– A[i][k]*A[j][i]/A[i][i]A[j][k] = A[j][k]堆排序堆排序主要包括两个步骤:对于给定的数组构造相应的堆。
第 五 章 减治法

算 分 析 与 设 计
西南科技大学
金块问题
有一个老板有一袋金块。每个月将有两 名雇员会因其优异的表现分别被奖励一 个金块。按规矩,排名第一的雇员将得 到袋中最重的金块,排名最后的雇员将 得到袋中最轻的金块。如果每个月都有 新的金块周期性的加入袋中,则每个月 都必须找出最轻和最重的金块。假设有 一台比较重量的仪器,我们希望用最少 的比较次数找出最轻和最重的金块。
算 分 析 与 设 计
西南科技大学
直接插入排序实现方法
减一技术下,该方法遵循的思路是:假设对较 小数组 A[0..n-2]排序问题已经解决了,得到一 个大小为n-1的有序数组。然后将要排序的第n 个元素,插入到数组的适合位置上,得到大小 为n的有序数组 A[0..n-1]。伪代码如下: void InsertionSort(a[]) {for(i=1;i<n-1;i++) //从第二个记录起进行插入 for (j=i-1; j>=0;j--) if a[j+1]-(a[j]) < 0 Swap(a[j+1], a[j]); }
算 分 析 与 设 计
西南科技大学
俄式乘法☺ 俄式乘法☺
算法思想:两个A和B数相乘,把数A每 次除以2,直到为0为止,另一个数B则不 断加倍,若第数A未除尽时,则数B应加 上自己。 7×8的计算步骤: 7 8 3 16+ 8 1 32+ 16 + 8
算 分 析 与 设 计
西南科技大学
约瑟夫斯问题( 约瑟夫斯问题(一)
算 分 析 与 设 计
西南科技大学
减常数因子减治法
减常数因子减治法的一个 典型算法就是折半查找 (Bin_Search)。它搜索 一个排序好的数组,将查 找目标与数组的中间位置 的元素相比,比它大则递 归查找数组的左边,反之 亦然。这个每次迭代都将 问题减小为原来的1/2。 折半查找每次都消去一个 常数因子2,因此其时间 效率为O(logn)。
第7章 减治法(《算法设计与分析(第3版)》C++版 王红梅 清华大学出版社)

比较对象,若 k 与中间元素相等,则查找成功;若 k 小于中间元素,则在中间元
算 法 设
计
素的左半区继续查找;若 k 大于中间记录,则在中间元素的右半区继续查找。不
与 分
析
断重复上述过程,直到查找成功,或查找区间为空,查找失败。
( 第
版 )
k
清 华
大
学
[ r1 … … … rmid-1 ] rmid [ rmid+1 … … … rn ] (mid=(1+n)/2)
Page 4
3
7.1.2 一个简单的例子——俄式乘法
【问题】俄式乘法(russian multiplication)用来计算两个正整数 n 和 m 的乘积
,运算规则:如果 n 是偶数,计算 n/2×2m;如果 n 是奇数,计算(n-1)/2×2m+
m;当 n 等于 1 时,返回 m 的值。
算
法
俄式乘法的优点?
与 分 析
2. 测试查找区间[low,high]是否存在,若不存在,则查找失败,返回 0;
( 第
3. 取中间点 mid = (low+high)/2; 比较 k 与 rmid,有以下三种情况:
版 )
3.1 若 k < rmid,则 high = mid - 1;查找在左半区进行,转步骤2;
清 华
3.2 若 k > rmid,则 low = mid + 1;查找在右半区进行,转步骤2;
Page 12
7.2.2 选择问题
【想法】假定轴值的最终位置是 s,则: (1)若 k=s,则 rs 就是第 k 小元素; (2)若 k<s,则第 k 小元素一定在序列 r1 ~ rs-1 中; (3)若 k>s,则第 k 小元素一定在序列 rs+1 ~ rn 中。
XXXX年11月20日深圳聘任制公务员行政执法2

2010年11月20日深圳聘任制公务员行政执法单项选择题1、以下关于行政许可实施主体的标书中,正确的有〔〕。
A、可由法律、法规授权的具有治理公共事务职能的组织在法定授权范围内以自己的名义实施B、只能由具有行政许可权的行政机关以自己的名义实施C、能够托付一般公民和社会团体实施D、受托付的行政机关能够转托付解析:此题答案为A。
此题考查行政许可法知识。
?行政许可法?第二十三条规定“法律、法规授权的具有治理公共事务职能的组织,在法定授权范围内,以自己的名义实施行政许可。
被授权的组织适用本法有关行政机关的规定。
〞,另外依据第二十四条的规定,行政机关能够托付其他行政机关实施行政许可,受托付行政机关在托付范围内,以托付行政机关名义实施行政许可;不得再托付其他组织或者个人实施行政许可。
由此可知A为正确答案。
2、某县人民法院以受贿罪判处陈某有期徒刑7年,陈某不服提出上诉,市中级人民法院经审理认为原判事实不清、证据缺乏,发回原审人民法院重新审判,原审人民法院经审理退回县人民检察院补充侦查。
县人民检察院经补充侦查认定陈某构成犯罪证据缺乏,遂作出不起诉决定。
陈某提起国家赔偿请求,本案的赔偿义务时机应为〔〕。
A、县人民检察院和县人民法院B、县人民法院和市中级人民法院C、市中级人民法院D、县人民法院解析:此题答案为D。
此题考查国家赔偿法知识。
?国家赔偿法?第二十一条第四款规定“再审改判无罪的,作出原生效判决的人民法院为赔偿义务机关。
二审改判无罪,以及二审发回重审后作无罪处理的,作出一审有罪判决的人民法院为赔偿义务机关。
〞由此可知D为正确答案。
3、国务院或者经国务院授权的省、自治区、直辖市人民政府能够决定一个行政机关行使有关行政机关的行政处分权,但〔〕的行政处分权只能由公安机关行使。
A、限制人身自由B、较大数额的罚款C、撤消企业营业执照D、责令停产停业解析:此题答案为A。
此题考查行政处分法知识。
?行政处分法?第十六条规定“国务院或者经国务院授权的省、自治区、直辖市人民政府能够决定一个行政机关行使有关行政机关的行政处分权,但限制人身自由的行政处分权只能由公安机关行使。
算法设计与分析智慧树知到答案章节测试2023年山东交通学院

第一章测试1.解决一个问题通常有多种方法。
若说一个算法“有效”是指( )A:这个算法能在人的反应时间内将问题解决B:(这个算法能在一定的时间和空间资源限制内将问题解决)和(这个算法比其他已知算法都更快地将问题解决)C:这个算法能在一定的时间和空间资源限制内将问题解决D:这个算法比其他已知算法都更快地将问题解决答案:B2.农夫带着狼、羊、白菜从河的左岸到河的右岸,农夫每次只能带一样东西过河,而且,没有农夫看管,狼会吃羊,羊会吃白菜。
请问农夫能不能过去?()A:不一定B:不能过去C:能过去答案:C3.下述()不是是算法的描述方式。
A:自然语言B:程序设计语言C:E-R图D:伪代码答案:C4.有一个国家只有6元和7元两种纸币,如果你是央行行长,你会设置()为自动取款机的取款最低限额。
A:40B:42C:29D:30答案:D5.算法是一系列解决问题的明确指令。
()A:对B:错答案:A6.程序=数据结构+算法()A:错B:对答案:B7.同一个问题可以用不同的算法解决,同一个算法也可以解决不同的问题。
()A:错答案:B8.算法中的每一条指令不需有确切的含义,对于相同的输入不一定得到相同的输出。
( )A:错B:对答案:A9.可以用同样的方法证明算法的正确性与错误性 ( )A:对B:错答案:B10.求解2个数的最大公约数至少有3种方法。
( )A:错B:对答案:A11.没有好的算法,就编不出好的程序。
()A:对B:错答案:A12.算法与程序没有关系。
( )A:错B:对答案:A13.我将来不进行软件开发,所以学习算法没什么用。
( )A:对B:错答案:B14.gcd(m,n)=gcd(n,m m od n)并不是对每一对正整数(m,n)都成立。
( )A:错B:对答案:A15.既然程序设计语言可以描述算法,所以算法就是程序。
( )A:错B:对答案:A第二章测试1.并不是所有的算法,规模更大的输入需要更长的运行时间。
( )A:对答案:B2.算法效率分析框架主要关心一个算法的基本操作次数的增长次数,并把它作为算法效率的主要指标。
减轻行政处罚应适用的处罚程序

又 有 可能 违反 罚 责 相应 , 即当 出现 了某 些 条 件 , 对这 些 违法 行 为在 法定 幅度 以下 给予 与处 罚则 更能 体现 公平 、 正 。 以《 公 所 行
政处 罚法 》 二十七 条 才做 出 了减轻 处罚 的规定 。从 以上 分 析 第 可 以看 出 , 行减 轻 处罚 必 须 满足 法定 条 件 , 进 而二十 七条 规 定 的条件 非 常严 格 ,四个 条件 中的其 中任何 一个 当场 都无 法 判 明。 因此 , 法本 意是 减轻处 罚 不能适 用 简易 程序 而应 适用 一 立 般程 序 。其 次 , 简易程序 不存 在减轻 处罚 的情形 。执 法实 践 中, 当场 做 出处罚 决定 的案 件 , 是 一些 案情 简单 、 了 , 害性 不 都 明 危 大, 处罚较 轻 的案件 。在这些 案件 中 , 如果 违法 行为轻 微 当事人 并 当场 纠正到 位 又没有 造成 后果 的 , 应适 用 二 十七条 第二 款 则 “ 法行 为轻微 并及 时 纠正 , 违 没有 造成 危害后 果 的 , 予行 政 处 不
行 政处 罚时 , 必须遵 循 立案 、 调查 取证 、 向相 对人 告知 其依 法 亨
有的权 利 和应 履 行 的义务 、 执法 人 员初 步 处罚 意 见 、 出处 罚 做
决定 和送达 行政处 罚决 定 书等一 定 的程序 。否 则 , 政 处罚 不 行 成立 。根据《 政处罚 法》 行 的规定 , 一般程 序适 用的条 件是 , 除适 用简 易程序处罚 以外 的其他 所有 行政违 法行 为。其特 点是程 序 严格 , 大限度 的体 现公正 。要求 执法人 员在 调查 收集证 据 、 最 现 场检查 时 , 少 于两人 , 不 并应 向 当事人 或者 有关 人员 出示 证件 , 告知权 利 、 义务 。证据 收集 必须遵 循合法 性 、 关联 性和 全面性 原
冀州市林业局行政处罚裁量权基准制度

冀州市林业局行政处罚裁量权基准制度1、盗伐森林或其他林木法律依据:(1)《中华人民共和国森林法》第三十九条:“盗伐森林或者其他林木的,依法赔偿损失;由林业主管部门责令补种盗伐株数十倍的树木,没收盗伐的林木或者变卖所得,并处盗伐林木价值三倍以上十倍以下的罚款。
滥伐森林或者其他林木,由林业主管部门责令补种滥伐株数五倍的树木,并处滥伐林木价值二倍以上五倍以下的罚款。
拒不补种树木或者补种不符合国家有关规定的,由林业主管部门代为补种,所需费用由违法者支付。
盗伐、滥伐森林或者其他林木,构成犯罪的,依法追究刑事责任。
”(2)《中华人民共和国森林法实施条例》第三十八条:“盗伐森林或者其他林木,以立木材积计算不足0.5立方米或者幼树不足20株的,由县级以上人民政府林业主管部门责令补种盗伐株数10倍的树木,没收盗伐的林木或者变卖所得,并处盗伐林木价值3倍至5倍的罚款。
盗伐森林或者其他林木,以立木材积计算0.5立方米以上或者幼树20株以上的,由县级以上人民政府林业主管部门责令补种盗伐株数10倍的树木,没收盗伐的林木或者变卖所得,并处盗伐林木价值5倍至10倍的罚款。
”细化标准:责令补种盗伐株数十倍的树木,没收盗伐的林木或者变卖所得,并按下列标准处罚:1.盗伐森林或者其他林木,以立木材积计算,0.5立方米以下或者幼树不足20株的,处以盗伐林木价值3至5倍的罚款。
2.盗伐森林或者其他林木的,以立木材积计算,0.5至1.5立方米或者幼树20株至50株的,处以盗伐林木价值5至8倍的罚款。
3.盗伐森林或者其他林木的,以立木材积计算,1.5立方米以上或者幼树50株以上的,处以盗伐林木价值8至10倍的罚款。
2、滥伐森林或其他林木法律依据:(1)《中华人民共和国森林法》第三十九条:“盗伐森林或者其他林木的,依法赔偿损失;由林业主管部门责令补种盗伐株数十倍的树木,没收盗伐的林木或者变卖所得,并处盗伐林木价值三倍以上十倍以下的罚款。
滥伐森林或者其他林木,由林业主管部门责令补种滥伐株数五倍的树木,并处滥伐林木价值二倍以上五倍以下的罚款。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
算 分 析 与 设 计
西南科技大学
折半插入排序
直接插入排序算法简洁,易理解,容易 实现。当序列中的记录值较小时,它是 较佳的排序方法。但是,通常待排记录 的数量很大,此时直接插入排序就不适 用了。 对有序表采用折半查找,其性能优于顺 序查找,所以直接插入排序算法中的 “搜索”操作,从减少“比较”次数着 眼,可在区间[0,i-1]上进行折半查找来 实现。
下面用减治法对这个问题进行求解。当n≤2时,识别 出最重和最轻的金块,一次比较就足够了。当n>2时, 可先把这袋金块平分成两个小袋A和B。然后分别找出 在A和B中最重和最轻的金块。设A中最重和最轻的金 块分别为HA与LA,以此类推,B中最重和最轻的金块 分别为HB和LB。通过比较HA和HB及LA和LB ,可以找 到所有金块中最重和最轻的。若n>2,则递归地应用 减治法。 设f(n)为使用分而治之方法所需要的比较次数。假设n 是2的幂。当n>2时,f(n)=2f(n/2)+2;当n=2时,f(n)为 1 。使用迭代方法可知f(n) =3n/2-2。使用减治法比逐 个比较的方法少用了25%的比较次数。
算 分 析 与 设 计
西南科技大学
约瑟夫斯问题的解
对约瑟夫斯问题,当n=2a+b时,有公式表示如下: L(n)=1+2b。
其中的b值不小于0 。
算 分 析 与 设 计
当把b=n-2a代入后,上述公式就转化为: L(n)=1+2n-21+[log2n]。
其中方括号表示取整数,n表示总人数。
约瑟夫斯问题(当n=41)的计算步骤: 因n=2a+b,此a最大取5,这时2a=32,所以b=9 。 把b=9代入L(n),故在这里L(41)=19。因此站在19号位上 就不会死了。
算 分 析 与 设 计
西南科技大学
减常量减治法
减常量减治法的 典型例子就是插 入排序,它运用 的是减一技术。
算 分 析 与 设 计
西南科技大学
直接插入排序
通常将一个记录A[i](i=2,3,…,n)插入 直接插入排序与打扑克时整理手上的牌 到当前的有序表,使得插入后仍保证该 非常类似。摸来的第1张牌无须整理,此 区间里的记录是按关键字有序的操作称 后每次从桌上的牌(无序区)中摸最上面的 第i-1趟直接插入排序。在排序过程的某 1张并插入左手的牌(有序区)中正确的位 一中间时刻,A被划分成两个子区间 置上。为了找到这个正确的位置,须自 A[1..i-1](有序区)和a[i..n](无序区)。 左向右(或自右向左)将摸来的牌与左手中 直接插入排序的基本操作是将当前无序 已有的牌逐一比较。 区的第1个记录R[i]插人到有序区R[1..i-1] 中适当的位置上,使R[1..i]变为新的有序 区。
约瑟夫斯问题,是以弗拉瓦斯.约瑟夫斯的名 字命名的,他是一个著名的犹太历史学家,参 加并记录了公元66-70年犹太人反抗罗马 的起义,约瑟夫斯做为一个将军,设法守住了 裘达伯特的堡垒达47天之久,但是在城市沦 陷了以后,他和40名死硬的将士在附近的一 个洞穴中避难。在那里,这些叛乱者表决说 “要投降毋宁死”。于是,约瑟夫斯建议没个 人轮流杀死他旁边的人,而这个顺序是有抽签 决定的,约瑟夫斯有预谋地拿到了他想要的那 个签~而没死~♤ ♤
算 分 析 与 设 计
西南科技大学
一趟折半插入排序伪代码
binpass(R[],i) {temp=R[i]; //temp是监视哨,且是 是监视哨, 是监视哨 且是R[i]的副本 的副本 S=1; j=i-1; //s和j分别指示折半查找区间 和 分别指示折半查找区间 while s<=j 的下界和上界 {m=(s+j)/2; // 在 有 序 区 R[1..i-1] 中 if temp<r[m] j=m-1; 进行折半查找以确定 else s=m+1;} R[i]的插入位置 的插入位置 for (k=i-1;k<= j+1;k--) R[k+1]=R[k]; //记录后移 记录后移 R[j+1]=temp;}
算 分 析 与 设 计
西南科技大学
约瑟夫斯问题( 约瑟夫斯问题(二)
这个著名问题在西方被称为约瑟夫斯(Josephus)问 题,在日本被称为继子立问题,在中国的民间传 说以八仙落座的形式表述。均为同一类问题不同 方面,可谓是浅入深出(浅到小学生兴趣很浓, 深到大学生有研究课题)。 与约瑟夫斯问题类似的问题很多。例如:用1 到6 摆成一个圆圈。先取1,然后每数k 枚棋子就取出 第k枚棋子。要是取出的顺序刚好是1,2,3,4, 5,6。问k=?
算 分 析 与 设 计
西南科技大学
减常数因子减治法
减常数因子减治法的一个 典型算法就是折半查找 (Bin_Search)。它搜索 一个排序好的数组,将查 找目标与数组的中间位置 的元素相比,比它大则递 归查找数组的左边,反之 亦然。这个每次迭代都将 问题减小为原来的1/2。 折半查找每次都消去一个 常数因子2,因此其时间 效率为O(logn)。
算法中引进附加记录temp有两个作 算法中引进附加记录temp有两个作 temp 其一是进入查找循环之前, 用:其一是进入查找循环之前,它 保存了a[i]的值, a[i]的值 保存了a[i]的值,使得不致于因记 录的后移而丢失a[i]中的内容; a[i]中的内容 录的后移而丢失a[i]中的内容;其 二是在while循环监视”下变量j while循环监视 二是在while循环监视”下变量j是 //从第二个记录起进行插入 //从第二个记录起进行插入 否越界,一旦越界( j<1), 否越界,一旦越界(即j<1),a[0] 自动控制While循环的结束, While循环的结束 自动控制While循环的结束,从而 避免了在While While循环中每一次都要 避免了在While循环中每一次都要 检测j是否越界( 检测j是否越界(即省略了循环条件 //将第 个记录赋值给第j+1 将第j //将第j个记录赋值给第j+1 j>=1”)。因此我们把称为“ “j>=1”)。因此我们把称为“监 个记录, 个记录,直至关键字不大 视 这种技巧, 哨”于待插入记录的关键字 。这种技巧,使得测试循环条 件的时间大约减少一半, 件的时间大约减少一半,对于记录 //将第 将第i //将第i个记录插入 数较大的文件, 数较大的文件,节约的时间相当可 观。
西南科技大学
第 五 章 减治法
什么是减治法?
就是在处理问题的过程中,不断减小被处理 的问题规模的方法。
算 分 析 与 设 计
减治法的设计思想
减治技术通过建立原问题实例的解和同样问 题较小实例的解的关系,并利用这种关系, 从顶而下(递归地)或从底而上(非递归地) 解决问题。一般情况下,每次算法迭代,都 消去一个常量和一个常数因子。
算 分 析 与 设 计
西南科技大学
直接插入排序的时间复杂度
整个排序过程为进行n-1趟插入,即:先 将序列中的第1个记录看成是一个有序的 子序列,然后从第2个记录起逐个进行插 入,直至整个序列变成按从小到大排列 为止。 直接插入排序的时间复杂性为0(n2)。从 空间来看,它只需要一个记录的辅助故 空间复杂度为0(1).
仅仅通过一次重量的比较,就可以判断伪币是否存在。
算 分 析 与 设 计
西南科技大学
金块问题
有一个老板有一袋金块。每个月将有两 名雇员会因其优异的表现分别被奖励一 个金块。按规矩,排名第一的雇员将得 到袋中最重的金块,排名最后的雇员将 得到袋中最轻的金块。如果每个月都有 新的金块周期性的加入袋中,则每个月 都必须找出最轻和最重的金块。假设有 一台比较重量的仪器,我们希望用最少 的比较次数找出最轻和最重的金块。
算 分 析 与 设 计
西南科技大学
实现过程
设n=8,有下列8个数,要求从小到大排序,每 次插入时数据的变化如下: 初始状态 : [7] 2 5 1 9 6 8 3 i=1监视哨(2) : [2 7] 5 1 9 6 8 3 i=2监视哨(5) : [2 5 7] 1 9 6 8 3 i=3监视哨(1) : [1 2 5 7] 9 6 8 3 i=4监视哨(9) : [1 2 5 7 9] 6 8 3 i=5监视哨(6) : [1 2 5 6 7 9] 8 3 i=6监视哨(8) : [1 2 5 6 7 8 9] 3 i=7监视哨(3) : [1 2 3 5 6 7 8 9]
算 分 析 与 设 计
西南科技大学
俄式乘法☺ 俄式乘法☺
算法思想:两个A和B数相乘,把数A每 次除以2,直到为0为止,另一个数B则不 断加倍,若第数A未除尽时,则数B应加 上自己。 7×8的计算步骤: 7 8 3 16+ 8 1 32+ 16 + 8
算 分 析 与 设 计
西南科技大学
约瑟夫斯问题( 约瑟夫斯问题(一)
西南科技大学
常见的减治法算法
最常见的减治法有:
减常量减治法,典型的就是插入排序,问题 规模每次都减1;还有计算a的n次方,可以计 算a的n-1次方,再变成计算a的n-2次方等等。 减常数因子减治法,典型的就是折半查找, 每次都把n/2个元素删去;还有约瑟夫斯问题 约瑟夫斯问题。 约瑟夫斯问题 减可变规模减治法法,典型的就是选择问题, 每次问题规模的减小量都在1到n之间;还有 二叉树的查找。
算 分 析 与 设 计
西南科技大学
直接插入排序的另一种写法
insertionsort(a,n) int *a,n {int i,j,temp; for (i=1;i<=n-1;i++) temp=a[i]; j=i-1; while temp<a[j] {a[j+1]=a[j]; j=j-1;} a[j+1]=temp }
算 分 析 与 设 计
西南科技大学
直接插入排序实现方法
减一技术下,该方法遵循的思路是:假设对较 小数组 A[0..n-2]排序问题已经解决了,得到一 个大小为n-1的有序数组。然后将要排序的第n 个元素,插入到数组的适合位置上,得到大小 为n的有序数组 A[0..n-1]。伪代码如下: void InsertionSort(a[]) {for(i=1;i<n-1;i++) //从第二个记录起进行插入 for (j=i-1; j>=0;j--) if a[j+1]-(a[j]) < 0 Swap(a[j+1], a[j]); }