欢迎来到天天文库
浏览记录
ID:43349706
大小:19.60 KB
页数:5页
时间:2019-09-30
《分治算法举例》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、1设X[0:n-1]和Y[0:n-1]为两个数组,每个数组中含有n个已排序好的数。试设计一个O(logn)时间的分治算法,找出X和Y的2n个数的中位数,并证明算法的时间复杂性为O(logn)。注:个数为奇数,则处于最中间位置的数;个数为偶数,则中间两个数据的平均数。解:利用二分查找思想:对于两个等长的数组,如果数组长度为奇数,令mid为数组的最中间元素的位置,则有X[mid],Y[mid]分别为两个数组的中位数,则存在以下情况:(1)如果X[mid]2、[mid:n-1]和Y[0:mid]中查找;(2)如果X[mid]>Y[mid],则两个数组合并后的中位数应该在X[0:mid]和Y[mid:n-1]中查找;(3)如果X[mid]=Y[mid],则两个数组合并后的中位数就是X[mid]或者Y[mid]另外考虑特殊情况:如果两个数组的长度为1,则无需比较大小,合并后数组的中位数即为两个数组元素的平均值。如果数组的长度为偶数,令mid为数组的中间两个元素的较小元素的位置,此时数组X的中位数为x=(X[mid]+X[mid+1])/2.0,数组Y的中位3、数为y=(Y[mid]+Y[mid+1])/2.0(这里考虑到中位数不一定为整数)。则存在以下情况:(1)如果xy,则两个数组合并后的中位数应该在X[0:mid]和Y[mid+1:n-1]中查找;(3)如果x=y,则两个数组合并后的中位数就是x或者y.考虑特殊情况:如果两个数组的长度为2,则如果其中一个数组A的元素刚好处于合并后的数组的中间位置,则最终的中位数为这个数组A的数组元素的平均数。否则,则4、回到数组长度为偶数的一般情况。具体如下:doubleSearch_Median(int*A,intl1,intr1,int*B,intl2,intr2,intn){/*如果两个数组的长度为,则中位数为所有元素的平均数,其中A,B为要查中位数的数组,l1,r1,l2,r2分别为两个数组每次查询的起始位置和终点位置n为两个数组每次查询时的范围(重新查询的数组长度)*/if(n==1){//数组长度为1的情况return(A[l1]+B[l2])/2.0;}if(n==2){//数组长度为2的情况if(5、A[l1]>B[l1]&&A[r1]B[r2])return(B[l2]+B[r2])/2.0;else;}//这里使用mid1,mid2分别来记录两个数组每次变化后的中间位置intmid1=(r1+l1)/2;intmid2=(r2+l2)/2;//如果数组的长度为偶数,对数组进行查询if(n%2==0){//这里考虑到偶数数组的中位数是中间两个数的平均数doublex=(A[mid6、1]+A[mid1+1])/2.0;doubley=(B[mid2]+B[mid2+1])/2.0;if(x7、d1]aj,则(ai,aj8、)构成了一个逆序对,请使用分治方法求整个序列中逆序对个数,并分析算法的时间复杂性。例如:序列(4,3,2)逆序对有(4,3),(4,2),(3,2)共3个解:数据输入:a数组,n(元素个数)采用归并排序思想:将序列看成一个数组假设f(i,j)为i到j的逆序对个数,取一个分割点k,假设s(i,j,k)表示以k为分割点,第一个元素在i到k中,第二个元素在k+1到j中形成的逆序对数。那么可以形成一个递归式:f(i,j)=f(i,k)+f(k+1,j)+s(i,j,k).采用归并排序算法进
2、[mid:n-1]和Y[0:mid]中查找;(2)如果X[mid]>Y[mid],则两个数组合并后的中位数应该在X[0:mid]和Y[mid:n-1]中查找;(3)如果X[mid]=Y[mid],则两个数组合并后的中位数就是X[mid]或者Y[mid]另外考虑特殊情况:如果两个数组的长度为1,则无需比较大小,合并后数组的中位数即为两个数组元素的平均值。如果数组的长度为偶数,令mid为数组的中间两个元素的较小元素的位置,此时数组X的中位数为x=(X[mid]+X[mid+1])/2.0,数组Y的中位
3、数为y=(Y[mid]+Y[mid+1])/2.0(这里考虑到中位数不一定为整数)。则存在以下情况:(1)如果xy,则两个数组合并后的中位数应该在X[0:mid]和Y[mid+1:n-1]中查找;(3)如果x=y,则两个数组合并后的中位数就是x或者y.考虑特殊情况:如果两个数组的长度为2,则如果其中一个数组A的元素刚好处于合并后的数组的中间位置,则最终的中位数为这个数组A的数组元素的平均数。否则,则
4、回到数组长度为偶数的一般情况。具体如下:doubleSearch_Median(int*A,intl1,intr1,int*B,intl2,intr2,intn){/*如果两个数组的长度为,则中位数为所有元素的平均数,其中A,B为要查中位数的数组,l1,r1,l2,r2分别为两个数组每次查询的起始位置和终点位置n为两个数组每次查询时的范围(重新查询的数组长度)*/if(n==1){//数组长度为1的情况return(A[l1]+B[l2])/2.0;}if(n==2){//数组长度为2的情况if(
5、A[l1]>B[l1]&&A[r1]B[r2])return(B[l2]+B[r2])/2.0;else;}//这里使用mid1,mid2分别来记录两个数组每次变化后的中间位置intmid1=(r1+l1)/2;intmid2=(r2+l2)/2;//如果数组的长度为偶数,对数组进行查询if(n%2==0){//这里考虑到偶数数组的中位数是中间两个数的平均数doublex=(A[mid
6、1]+A[mid1+1])/2.0;doubley=(B[mid2]+B[mid2+1])/2.0;if(x7、d1]aj,则(ai,aj8、)构成了一个逆序对,请使用分治方法求整个序列中逆序对个数,并分析算法的时间复杂性。例如:序列(4,3,2)逆序对有(4,3),(4,2),(3,2)共3个解:数据输入:a数组,n(元素个数)采用归并排序思想:将序列看成一个数组假设f(i,j)为i到j的逆序对个数,取一个分割点k,假设s(i,j,k)表示以k为分割点,第一个元素在i到k中,第二个元素在k+1到j中形成的逆序对数。那么可以形成一个递归式:f(i,j)=f(i,k)+f(k+1,j)+s(i,j,k).采用归并排序算法进
7、d1]aj,则(ai,aj
8、)构成了一个逆序对,请使用分治方法求整个序列中逆序对个数,并分析算法的时间复杂性。例如:序列(4,3,2)逆序对有(4,3),(4,2),(3,2)共3个解:数据输入:a数组,n(元素个数)采用归并排序思想:将序列看成一个数组假设f(i,j)为i到j的逆序对个数,取一个分割点k,假设s(i,j,k)表示以k为分割点,第一个元素在i到k中,第二个元素在k+1到j中形成的逆序对数。那么可以形成一个递归式:f(i,j)=f(i,k)+f(k+1,j)+s(i,j,k).采用归并排序算法进
此文档下载收益归作者所有