2011年计算机二级C++辅导实例编程(25)

来源:计算机等级考试    发布时间:2012-08-29    计算机等级考试视频    评论

  用C++实现合并排序

  合并排序的思想:当只有一个元素时终止排序,超过一个元素的话,将所有元素分成大致相同的两个集合,分别对两个集合进行排序,最后将排好序的子集合合并为所要求的排好序的集合。

  在最坏情况下,时间复杂度为O(nlogn),它是一个渐进的最优算法。

  #include

  #include

  //这个函数将b[0]至b[right-left+1]拷贝到a[left]至a[right]

  template

  void Copy(T a[],T b[],int left,int right)

  {

  int size=right-left+1;

  for(int i=0;i

  {

  a[left++]=b[i];

  }

  }

  //这个函数合并有序数组a[left:i],a[i+1:right]到b,得到新的有序数组b

  template

上一页12下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答