|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- /* 初始条件:顺序线性表L已存在,1<=i<=ListLength(L)。 */
- /* 操作结果:在L中第i个位置之前插入新的数据元素e,L长度+1。*/
- Status ListInsert(SqList *L, int i, ElemType e)
- {
- int k;
- if( L->length == MAXSIZE ) // 顺序线性表已经满了
- {
- return ERROR;
- }
- if( i<1 || i>L->length+1) // 当i不在范围内时
- {
- return ERROR;
- }
- if( i <= L->length ) // 若插入数据位置不在表尾
- {
- /* 将要插入位置后数据元素向后移动一位 */
- for( k=L->length-1; k >= i-1; k-- )
- {
- L->data[k+1] = L->data[k];
- }
- }
- L->data[i-1] = e; // 将新元素插入
- L->length++;
- return OK;
- }
复制代码
各位大佬这地方怎么是 if( i<1 || i>L->length+1) 不应该只是length吗????
0101010 假设是一个长度为3的线性表,0表示可插入的位置。最多能插入到第四位。
|
|