当前位置: 首页 > wzjs >正文

企业网站怎么注册青海省建设厅网站职称评审表

企业网站怎么注册,青海省建设厅网站职称评审表,外贸网站建设网页,网站开发公司名单一.大根堆的创建创建大根堆,以下是前置基础代码。(array 是需要被调整为大根堆的数组,elem 是用来展现array被调整之后为大根堆的数组)public int[] elem;public int usedsize;public Heap(){this.elem new int[10];}public void…

一.大根堆的创建

创建大根堆,以下是前置基础代码。(array 是需要被调整为大根堆的数组,elem 是用来展现array被调整之后为大根堆的数组)

    public int[] elem;public int usedsize;public Heap(){this.elem = new int[10];}public void init(int[] array){for (int i = 0; i < array.length; i++) {elem[i] = array[i];usedsize ++;}}

 创建大根堆的思想是:我们通过 (usedsize -1-1)/2 来找到 parent 节点,再通过 parent 节点来找到 child 节点,通过比较下标为 child 和 child+1 两个节点,来找到值较大的节点和 parent 节点来比较,比较之后再来确定要不要对节点来进行交换,比如:我有一个数组{4,2,3,1,5,6,7}以下的3就是我们找到的 parent 节点,6就是我们找到的 child 节点。如图所示 child 节点是比child+1 节点要小的,所以我们让 child+1 节点和 parent 节点比较, child+1 节点要大于 parent 节点,进行更换之后如图二

图一

 图二就是进行交换之后的状态,此时 7,6,3,构成一个小的大根堆,按代码,我们需要让parent--,并且重新找child节点,如图三:

 图二

 对图三中我们继续进行比较和更换操作得到图四:

                              图三                                                                             图四

在图四的基础上,parent-- ,重复比较和更换的操作,我们可以发现,图五已经结束,但整个堆并不是大根堆,对顶上进行调整之后,其他地方也发生了改变,接下来我们需要进行的操作就是向下 调整,由于是 4 和 7 两个交换了值,所以交换之后,我们需要对 4 节点重新进行调整,让 parent = child+1 节点,重新找child 节点,重新进行调整,调整之后就会发现我们已经完成了创建大根堆的操作。

                          图五                                                                                  图六

代码展示:

    public void GreatHeap(){for (int parent =( usedsize -1-1)/2; parent >= 0; parent--) {siftmaxHeap(parent,usedsize);}}public void siftmaxHeap(int parent,int usedsize){int child = 2*parent + 1;while(child < usedsize){if(child +1 < usedsize && elem[child+1] > elem[child]){child++;}//elem[child] 跟 elem[parent] 进行比较,交换。if(elem[child] > elem[parent]){swap(elem,parent,child);parent = child;child = 2*parent +1;}else {break;}}}public void swap(int[] elem,int parent,int child){int k = elem[parent];elem[parent] = elem[child];elem[child] = k;}public void printf(){for (int i = 0; i < elem.length; i++) {System.out.print(elem[i]);}}
}

Test测试:

public class Test {public static void main(String[] args) {int[] array= {4,2,3,1,5,6,7};Heap ret = new Heap();ret.init(array);ret.GreatHeap();ret.printf();}
}

运行结果:  与预期结果相符

二.大根堆的插入

大根堆的插入我们需要用到向上调整,将插入的数值塞入到数组的最后一个位置,找到此位置的parent 节点,通过不断地循环比较,慢慢的将新数组调整为大根堆的形态。

代码:

    public void offer(int val){if(elem.length == usedsize){elem = Arrays.copyOf(elem,2*elem.length);}elem[usedsize] = val;usedsize++;siftup(usedsize);}public void siftup(int size){int parent = (size-1-1)/2;int child = size-1;while (parent >= 0){if (elem[child] > elem[parent]){swap(elem,parent,child);child = parent;parent = (child-1)/2;}else {break;}}}

 test测试:

public class Test {public static void main(String[] args) {int[] array= {4,2,3,1,5,6,7};Heap ret = new Heap();ret.init(array);ret.GreatHeap();ret.printf();System.out.println();ret.offer(9);ret.printf();}
}

 运行结果:   可以看到是符合预期结果的。

三.大根堆的删除

删除其中某个节点,以下代码提供的是删除节点的下标,如需删除某个值,可以先求出下标再删除,本文直接提供下标。我们将要删除的节点与数组的最后一个节点相交换,让usedsizie--,然后以删除的下标节点为主,进行向下调整,调整之后就可以实现大根堆的删除操作。

代码展示:

public void poll(int set){swap(elem,set,usedsize-1);usedsize--;siftmaxHeap(set,usedsize);}

text测试:

public class Test {public static void main(String[] args) {int[] array= {4,2,3,1,5,6,7};Heap ret = new Heap();ret.init(array);ret.GreatHeap();ret.printf();System.out.println();ret.poll(3);ret.printf();}
}

运行结果:符合预期(由于我们已经让usedsize--,数组空间为10固定不变,所以展现出来的结果只用看前六位即可)

四.tops-k问题

这个问题意思是,给你 n 个数据,让你来求这 n 个数据的前 k 个最大/最小的问题,这边以求前 k 个最小的值为例。我们将数组的前 k 个元素组成大根堆,然后将其余 n-k 个元素依次与堆顶的元素进行比较,如果小于堆顶的值,我们就将堆顶的值 poll 掉,并且将新的值添加进堆中(offer 代码在值添加进堆的时候,会对堆重新进行一次大根堆排列),以此类推下去,最后堆里面剩下的 k 个值就是我们要求的前 k 个最小值。 如果想求最大值的话,我们需要按此方式来对前 k 个元素创立小根堆。

    public void smallestk(int[] count,int k){for (int i = 0; i < k; i++) {offer(count[i]);}for (int i = k; i < count.length; i++) {int cur = peek();if (cur > count[i]){poll(0);offer(count[i]);}}}

测试:

        int[] count = {5,6,7,8,4,3,2,1};ret.smallestk(count,3);ret.printf();}

运行结果:  符合预期

关于 tops-k 问题,还有其余解法,例如通过冒泡排序来求前 k 个最小的值,通过建立小根堆,每次对堆顶的值进行记录并且 poll ,然后对余下的值继续排列小根堆,重复 k 次 也可以实现此问题。

http://www.dtcms.com/wzjs/788387.html

相关文章:

  • 云南网站开发报价大方县住房城乡建设局网站
  • 业网站制作百度搜索引擎的功能
  • 校园网站html模板windows优化大师有什么功能
  • 黄江网站仿做wordpress 4.8 中文版
  • 华为官方网站进入高水平 专业 建设 网站
  • 义乌网站建设工作室自己建网站需要什么软件
  • 中国做网站的公司有哪些新闻 最新消息
  • 奉贤网站建设番禺网络科技有限公司
  • 三屏营销型网站建设制作一个网站平台要多钱
  • 网站文件验证Wordpress仿appstore
  • 河源市建设网站最好的网站建设推广
  • 一鸣东莞网站建设公司在线整合营销推广
  • 学校建网站jsp可以做网站首页吗
  • 福建省住房城乡建设厅网站做相亲网站
  • 个人或主题网站建设wordpress关注
  • php 网站开发 视频清远做网站的
  • 深圳网站设计公司发展历程seo如何优化关键词排名
  • expedia电子商务网站建设赤壁专业建站公司
  • 网站数据接口怎么做吉林网站优化
  • 必应站长平台网站建设教程.
  • 网站开发视频教程迅雷下载山西省吕梁市天气
  • 网站页面的组成网站开发引用思源黑体
  • 昆明网站建设系统有哪些天元建设集团有限公司滨州分公司是国企吗
  • 企业网站建设源码 微信 手机哈尔滨建站免费模板
  • 国外网站翻墙怎么做手机网站布局
  • 网站功能设计有哪些要求大连做网站哪家便宜
  • 吉林省绥中县城乡建设局网站海淘一号 网站 怎么做的
  • 沭阳城乡建设局网站网站开发微信小程序需求量大吗
  • 外贸网站一般用什么框架wordpress新闻编辑器
  • ui设计师作品集网站域名如何解绑一个网站