论坛首页 编程语言技术论坛

一个c语言数据结构的问题

浏览 4386 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-03-18  
C
我先不说什么,先看下面的代码:
cpp 代码
  1. void delete_pos_sequence_list(sequence_list *slt,int position)   
  2. {   
  3.   int i;   
  4.   if(slt->size==0)   
  5.   {   
  6.          printf("\n顺序表是空的!");   
  7.          exit(1);   
  8.   }   
  9.   if(position<0 | | position>=slt->size)   
  10.   {   
  11.         printfI("\n指定的删除位置不存在!");   
  12.         exit(1);   
  13.    }   
  14.   for(i=position;i< slt- >size-1;i--)   
  15.   {   
  16.      slt->a[i]=slt->a[i+1];   
  17.   }   
  18.   slt->size--;   
  19. }  

这是我从书上看到的一个数据结构的代码,主要是实现删除顺序表中的第position位置的节点。我看了很久总觉得这个代码有点问题,就是在第14行for语句中,那个i--应该是i++吧,要是i总减永远也比slt->size小啊。那么循环就一直下去,不会出来了啊。

请高手给小弟指明下,是不是有问题,还是我理解错误。谢谢了。

我看了下,有的地方显示有问题:第9行应该是:if (position<0 || position >=slt->size)  晕,在编辑里是正确的,显示出来是错的。主要是说的position必须不小与0或者不大于等于slt->size。

第14行看不到,应该是:for(i=position;i< slt- >size-1;i--)   

   发表时间:2007-03-19  
就应该是i++.
0 请登录后投票
   发表时间:2007-03-19  
这个代码...
如果是书本上的实在是误人子弟了
for(i=position;i< slt- >size-1;i--)   
  {   
     slt->a[i]=slt->a[i+1];   
  }   
应该是i++, 但是更加有效的方法是用memcpy之类的库函数,这类函数会有优化,速度快
0 请登录后投票
   发表时间:2007-03-20  
恩,知道了,我也这样认为,呵呵。谢谢大家了。
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics