Chinaunix首页 | 论坛 | 博客
  • 博客访问: 612724
  • 博文数量: 113
  • 博客积分: 2554
  • 博客等级: 少校
  • 技术积分: 1428
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-21 19:53
文章分类

全部博文(113)

文章存档

2014年(1)

2013年(2)

2012年(94)

2011年(16)

分类: LINUX

2011-12-31 10:03:58

1)顺序表:插入
  1. //v 线性表存储空间
  2. //m 线性表存储空间容量
  3. //n 线性表长度(即线性表中元素个数)
  4. //i 插入的位置(表示在第i个元素之前插入)
  5. //b 插入的新元素
  6.     #include <stdio.h>
  7.     void ins_sq_List(T *v, int m, int *n, int i, T b)
  8.     { int k;
  9.      if (*n==m) //存储空间已满,上溢错误
  10.      { printf("overflow\n" ); return; }
  11.      if (i>*n) i=*n+1; //默认为在最后一个元素之后插入
  12.      if (i<1) i=1; //默认为在第一个元素之前插入
  13.      for (k=*n; k>=i; k--)
  14.          v[k]=v[k-1]; //从最后一个元素开始,直到第i个元素均往后移动一个位置
  15.      v[i-1]=b; //插入新元素
  16.      *n=*n+1; //线性表长度增加1
  17.       return;
  18.     }
删除
  1. //v 线性表存储空间
  2. //m 线性表存储空间容量
  3. //n 线性表长度(即线性表中元素个数)
  4. //i 删除的位置(表示删除第i个元素)
  5.     #include <stdio.h>
  6.     void del_sq_List(T *v, int m, int *n, int i)
  7.     { int k;
  8.      if (*n==0) //线性表为空,下溢错误
  9.          { printf("underflow!\n"); return; }
  10.       if ((i<1)||(i>*n)) //线性表中没有这个元素
  11.          { printf("Not this element in the list!\n");
  12.      return;
  13.      }
  14.      for (k=i; k<*n; k++)
  15.          v[k-1]=v[k]; //从第i个元素开始,直到最后一个元素均往前移动一个位置
  16.      *n=*n-1; //线性表长度减1
  17.       return;
  18.     }
2)栈
/* c3-1.h 栈的顺序存储表示 */
 #define STACK_INIT_SIZE 10 /* 存储空间初始分配量 */
 #define STACKINCREMENT 2 /* 存储空间分配增量 */
 typedef struct SqStack
 {
   SElemType *base; /* 在栈构造之前和销毁之后,base的值为NULL */
   SElemType *top; /* 栈顶指针 */
   int stacksize; /* 当前已分配的存储空间,以元素为单位 */
 }SqStack; /* 顺序栈 */


 /* bo3-1.c 顺序栈(存储结构由c3-1.h定义)的基本操作(9个) */
 Status InitStack(SqStack *S)
 { /* 构造一个空栈S */
   (*S).base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));
   if(!(*S).base)
     exit(OVERFLOW); /* 存储分配失败 */
   (*S).top=(*S).base;
   (*S).stacksize=STACK_INIT_SIZE;
   return OK;
 }
 Status DestroyStack(SqStack *S)
 { /* 销毁栈S,S不再存在 */
   free((*S).base);
   (*S).base=NULL;
   (*S).top=NULL;
   (*S).stacksize=0;
   return OK;
 }
 Status ClearStack(SqStack *S)
 { /* 把S置为空栈 */
   (*S).top=(*S).base;
   return OK;
 }
 Status StackEmpty(SqStack S)
 { /* 若栈S为空栈,则返回TRUE,否则返回FALSE */
   if(S.top==S.base)
     return TRUE;
   else
     return FALSE;
 }
 int StackLength(SqStack S)
 { /* 返回S的元素个数,即栈的长度 */
   return S.top-S.base;
 }
 Status GetTop(SqStack S,SElemType *e)
 { /* 若栈不空,则用e返回S的栈顶元素,并返回OK;否则返回ERROR */
   if(S.top>S.base)
   {
     *e=*(S.top-1);
     return OK;
   }
   else
     return ERROR;
 }
 Status Push(SqStack *S,SElemType e)
 { /* 插入元素e为新的栈顶元素 */
   if((*S).top-(*S).base>=(*S).stacksize) /* 栈满,追加存储空间 */
   {
     (*S).base=(SElemType *)realloc((*S).base,((*S).stacksize+STACKINCREMENT)*sizeof(SElemType));
     if(!(*S).base)
       exit(OVERFLOW); /* 存储分配失败 */
     (*S).top=(*S).base+(*S).stacksize;
     (*S).stacksize+=STACKINCREMENT;
   }
   *((*S).top)++=e;
   return OK;
 }
 Status Pop(SqStack *S,SElemType *e)
 { /* 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR */
   if((*S).top==(*S).base)
     return ERROR;
   *e=*--(*S).top;
   return OK;
 }
 Status StackTraverse(SqStack S,Status(*visit)(SElemType))
 { /* 从栈底到栈顶依次对栈中每个元素调用函数visit()。 */
   /* 一旦visit()失败,则操作失败 */
   while(S.top>S.base)
     visit(*S.base++);
   printf("\n");
   return OK;
 }
 
 
阅读(1216) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~