053.顺序表插入和删除

简介: 053.顺序表插入和删除
#define ListSize 100/* 假定表空间大小为100 */
#include <stdio.h>
#include <stdlib.h>
void Error(char * message)
{
printf("错误:%s\n",message);
exit(1);
}/* 从0开始计, 表空间大小应为101了 */
struct Seqlist{
int  data[ListSize];/* 向量data用于存放表结点 */
int length; /*  当前的表长度 */
};
/* 以上为定义表结构 */
/* ------------以下为两个主要算法---------- */
void InsertList(struct Seqlist *L, int x, int i)
{
/* 将新结点x插入L所指的顺序表的第i个结点ai的位置上 */
int j;
if ( i < 0 || i > L -> length )
Error("position error");/* 非法位置,退出 */
if ( L->length>=ListSize )
Error("overflow");
 for ( j=L->length-1 ; j >= i ; j --)
L->data[j+1]=L->data [j];
L->data[i]=x ;
L->length++ ;
}
void DeleteList ( struct Seqlist *L, int i )
{/* 从L所指的顺序表中删除第i个结点ai */
int j;
 if ( i< 0 || i > L-> length-1)
Error( " position error" ) ;
 for ( j = i+1 ; j < L-> length ; j++ )
    L->data [ j-1 ]=L->data [ j]; /* 结点前移 */
L-> length-- ; /* 表长减小 */
}
/* ===========以下为验证算法而加======= */
void Initlist(struct Seqlist *L)
{
  L->length=0;
}
void main()
{
   struct Seqlist *SEQA;
   int i;
   SEQA = (struct Seqlist *)malloc(sizeof(struct Seqlist));
   Initlist(SEQA);
   for (i=0;i<ListSize;i++)
   {  
     InsertList (SEQA,i,i);
     printf("%d\n",SEQA->data[i]);
   }
     DeleteList (SEQA,99);
   for (i=0;i<ListSize-1;i++)
   {
  printf("%d\n",SEQA->data[i]);
  }
}
相关文章
|
6月前
双链表的插入,删除以及遍历
双链表的插入,删除以及遍历
49 6
|
6月前
|
存储
单链表相关操作(插入,删除,查找)
单链表相关操作(插入,删除,查找)
55 4
|
6月前
顺序表的插入,删除,修改和查找(详细解析)
顺序表的插入,删除,修改和查找(详细解析)
80 5
|
6月前
|
算法 C语言
【408数据结构与算法】—顺序表的插入、删除和查找(四)
【408数据结构与算法】—顺序表的插入、删除和查找(四)
删除顺序表中指定值的所有元素
顺序表是一种使用数组实现的数据结构。删除顺序表中指定值的所有元素,可以按照以下步骤进行操作:
292 1
顺序表头插头删尾插尾删以及任意位置的插入删除和顺序表中的查找
顺序表头插头删尾插尾删以及任意位置的插入删除和顺序表中的查找
|
存储 C++
链表操作:插入、删除与遍历
(笔者画图不易呜呜)链表是一种基本的数据结构,它可以用来存储一系列的元素,并且支持灵活的插入、删除操作。在计算机科学中,链表常常用于构建更复杂的数据结构,如栈、队列以及图等。
328 0
|
算法 Java
优雅的删除链表元素
大家好,我是王有志。今天我们尝试使用多种方法,“优雅”的实现链表的删除方法。
148 0
优雅的删除链表元素
双链表全部知识总结(初始化、插入、删除、遍历)
双链表知识总结包括思路分析、代码实现
270 0
|
存储 C语言 C++
顺序表的插入、删除和查找(四)
详细介绍了数据结构中的顺序表
255 0