2011年软考程序员考试复习笔试知识点整理(5)

来源:软件水平考试    发布时间:2012-11-05    软件水平考试视频    评论

  希尔排序

  算法思想:先将整个待排序记录分割成若干子序列分别进行直接插入排

  序,待整个序列中的记录基本有序时,再对全体记录进行一

  次直接插入排序

  时间复杂度 o(n^2)

  空间复杂度 o(1)

  比较次数 ?

  */

  void shell_insert(int array[],int d,int len)

  {

  int tmp,j;

  for (int i = d;i < len;i++)

  {

  if(array[i] < array[i-d])

  {

  tmp = array[i];

  j = i - d;

  do

  {

  array[j+d] = array[j];

  j = j - d;

  } while (j >= 0 &&tmp < array[j]);

  array[j+d] = tmp;

  }

  }

  }

  void shell_sort(int array[],int len)

  {

  int inc = len;

  do

  {

  inc = inc/2;

  shell_insert(array,inc,len);

  } while (inc > 1);

  }

  /*

视频学习

我考网版权与免责声明

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

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

最近更新

社区交流

考试问答