Java实现最大二叉堆中找min<=x<max的x们

写在前面:
定义见上一篇文章
代码:

/**
* @description 最大二叉树中找a<=x<b的x
* @param min
* @param max
* @param array
* @return
*
* @author LynnWong
*/
private int[] getX(int min,int max,int[] array){
int rootSite = 0;
int n = 0;
int [] XArray = new int[array.length];
while(rootSite<array.length-1){
int root = array[rootSite];
if(root>min||root==min){
if((rootSite*2+1<array.length-1)&&(min==array[rootSite*2+1]||min<array[rootSite*2+1])&&array[rootSite*2+1] <max){
XArray[n++]=array[rootSite*2+1];
}
if((rootSite*2+1<array.length-1)&&(min==array[rootSite*2+2]||min<array[rootSite*2+2])&&array[rootSite*2+2] <max){
XArray[n++]=array[rootSite*2+2];
}
}else
break;
rootSite++;
}

return XArray;
}


/**
* @description 元素添加到末尾,和它的父节点比,如果比它大就交换
* @param array
*
* @author LynnWong
*/
private int[] getMaxBinaryHeap(int[] array){
int N = array.length;
int maxBinaryHeap[] = new int[N];
int root;//根的值
int heapSize = 0;//记录插入位置
for(int num : array){
maxBinaryHeap[heapSize]=num;
++heapSize;
int pointer = heapSize-1;//当前指向的数组元素位置
while(pointer!=0){
int leafPointer = pointer;//叶子节点位置
pointer = (pointer-1)/2;//根节点位置
root = maxBinaryHeap[pointer];//根节点
if(num<=maxBinaryHeap[pointer]){//永远把当前数组元素看成叶子与其根比较或者换位
break;
}//如果根比叶子小 就交换位置
maxBinaryHeap[pointer] = num;
maxBinaryHeap[leafPointer] = root;

}
}
return maxBinaryHeap;

}


/**
* 我就喜欢测10遍!
*/
public void text(){
for(int i=0;i<10;i++){
Random rnd = new Random();
int [] lala = {rnd.nextInt(8),rnd.nextInt(8),rnd.nextInt(8),rnd.nextInt(8),rnd.nextInt(8),rnd.nextInt(8)};
int array[] =
this.getMaxBinaryHeap(lala);
// {5,2,0,0,2,0};
int result[] = this.getX(3, 6, array);
System.out.print("输入:");
for(int a : array){
System.out.print(a+" ");
}
System.out.print(" 条件: 3<=x<6");
System.out.println();
System.out.print("输出:");
for(int a : result){
System.out.print(a+" ");
}
System.out.println();
}
}

完成!
*******************分割线啊分割线*********************
完成它,共用了10分钟。听的背景音乐:《好男人》张赫宣
lysh 你也听听啊!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值