鱼C论坛

 找回密码
 立即注册
查看: 1679|回复: 2

小甲鱼老师的线性表第三个视频的源码,我觉得有点错误,不知道对不对

[复制链接]
发表于 2019-5-10 15:19:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. Status ListInsert(SqList *L, int i, ElemType e)
  2. {
  3.     int k;
  4.     if( L->length == MAXSIZE )  // 顺序线性表已经满了
  5.     {
  6.         return ERROR;
  7.     }
  8.     if( i<1 || i>L->length+1)   // 当i不在范围内时
  9.     {
  10.         return ERROR;
  11.     }
  12.     if( i <= L->length )   // 若插入数据位置不在表尾
  13.     {
  14.         /* 将要插入位置后数据元素向后移动一位 */
  15.         for( k=L->length-1; k >= i-1; k-- )
  16.         {
  17.             L->data[k+1] = L->data[k];//这里是不是错了
  18.         }
  19.     }
  20.     L->data[i-1] = e;  // 将新元素插入
  21.     L->length++;
  22.     return OK;
  23. }
复制代码



那个for循环是不是多移动了一个位置

转换成数组的元素个数,应该都减个1
所以是不是应该是 L->data[k] = L->data[k-1];



ffb834511cfe7c2211c07ef31806cd3.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-5-10 16:27:22 | 显示全部楼层
你再仔细想一想,
提醒一下,第四个元素的下标是3,而第五个元素的下标是4
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-3 16:13:44 | 显示全部楼层

回帖奖励 +1 鱼币

私信问下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-11 18:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表