| | ****数据结构**** | |
| | 作者 | 留言 |
---|
让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: ****数据结构**** 周二 十一月 27, 2012 1:05 pm | |
| | |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: 数据结构之进栈和出栈 周二 十一月 27, 2012 12:42 pm | |
| #include <stdio.h> #include <stdlib.h> #define stack_init_size 100 #define stncrement 10 #define selemtype int typedef struct { selemtype *top; //该指针始终指向栈顶// selemtype *base; //该指针始终指向栈底// int stacdsize; // 栈当前的长度// }node; //栈的初始化int initstack(node &s)// s需要用引用 // { s.top=s.base=(selemtype*)malloc(stack_init_size*sizeof(selemtype)); //申请一块大小为stack_init_size的空间,同时把该空间的地址赋值给s.top和s.base// s.stacdsize=stack_init_size; //栈当前的长度大小为stack_init_size// return 0; } //元素入栈 int push(node &s,selemtype e) { if(s.top-s.base>= s.stacdsize) //判断栈是否已满// { s.base=(selemtype*)realloc(s.base,(s.stacdsize + stncrement)*sizeof(selemtype)); //如果栈已满,申请一块动态空间(相当于在原有的空间上增加一块大小为stncrement的空间,同时把新申请的空间的地址赋值给s.base)// s.top=s.base+s.stacdsize ; http://s.top始终指向要入栈的元素的位置// s.stacdsize+=stncrement; //栈的当前长度同时增加// } *s.top++=e; //首先把e的值赋给s.top,然后把s.top指向即将要来到的元素的位置// return 0;}//出栈int pop(node &s,selemtype &e) { if(s.top==s.base) //判断栈是否为空// return 1; e=*--s.top; //首先使s.top向下移动一位,然后把s.top指向的值赋给e// return 0; } //int stacikempty(node s) { if(s.base==s.top) return 1; else return 0; } //主函数void main() { node s; selemtype e; int n,i; printf("请输入一个数n="); scanf("%d",&n); printf("请输入一个进制数i="); scanf("%d",&i); initstack(s); while(n!=0) { e=n%i; //求出余数// push(s,e); //把余数入栈// n=n/i; //求出整数// } while(!stacikempty(s)) { pop(s,e); printf("%d\t",e); } }
| |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: C语言实现的链表队列数据结构 周二 十一月 27, 2012 12:40 pm | |
| // queue.cpp : Defines the entry point for the console application. //
#include "stdafx.h" #include<stdio.h> #include<ctype.h> #include<string.h> #include<malloc.h>
//定义链队节点类型 typedef struct LinkQueueNode { int data; struct LinkQueueNode * next; }LinkQueueNode;
//定义链队类型 typedef struct LinkQueue { LinkQueueNode *front,*rear; }LinkQueue;
//初始化队列 void InitQueue(LinkQueue *lq) { LinkQueueNode *p; p=(LinkQueueNode *)malloc(sizeof(LinkQueueNode)); lq->front=p; lq->rear=p; (lq->front)->next=NULL; }
//入队,入队节点值为x void EnterQueue(LinkQueue * lq,int x) { LinkQueueNode *p; p=(LinkQueueNode *)malloc(sizeof(LinkQueueNode)); p->data=x; p->next=NULL; (lq->rear)->next=p; lq->rear=p; }
//出队,出队节点值为x OutQueue(LinkQueue *lq,int *x) { LinkQueueNode *s; if(lq->front==lq->rear) { printf("队空"); return 0; } else { s=(lq->front)->next; *x=s->data; (lq->front)->next=s->next; if(s->next==NULL) lq->rear=lq->front; free(s); return 1; } }
//判断队列是否为空 EmptyQueue(LinkQueue lq) { if(lq.rear==lq.front) return 1; else return 0; }
//取队列头节点,队头节点值为x GetHead(LinkQueue lq,int *x) { LinkQueueNode *p; if(lq.rear==lq.front) return 0; else { p=lq.front->next; *x=p->data; return 1; } }
void main() { LinkQueue lq; int n; char ch; InitQueue(&lq); while(1) { printf("n请输入命令 A 入队; O 出队 L 显示队列内容:n"); scanf("%c",&ch);
switch(toupper(ch)) { case A: printf("请输入节点值,节点准备入队n"); scanf("%d",&n); EnterQueue(&lq,n); break; case O: if(!EmptyQueue(lq)) { OutQueue(&lq,&n); printf("值为%d的节点出队",n); } else printf("队列为空n"); break; case L: printf("下列节点依次出队n"); break; } if(toupper(ch)==L) { while(!EmptyQueue(lq)) { OutQueue(&lq,&n); printf("值为%d的节点出队n",n); } break; } } } | |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: 数据结构中二叉树的顺序存储结构代码 周二 十一月 27, 2012 12:37 pm | |
| #include <stdio.h> typedef char TElemType; // 二叉树的顺序存储表示 #define MAX_TREE_SIZE 100 // 二叉树的最大结点数 typedef TElemType SqBiTree[MAX_TREE_SIZE]; // 0号单元存储根结点 typedef struct { int level, //结点的层 order; //本层序号(按满二叉树计算) }position; typedef int QElemType; // 队列的顺序存储结构(可用于循环队列和非循环队列) #define MAXQSIZE 5 // 最大队列长度(对于循环队列,最大队列长度要减1) typedef struct { QElemType *base; // 初始化的动态分配存储空间 相当于一个数组 int front; // 头指针,若队列不空,指向队列头元素,相当于一个数组下标 int rear; // 尾指针,若队列不空,指向队列尾元素的下一个位置 // 相当于一个数组下标 }SqQueue; #define ClearBiTree InitBiTree // 在顺序存储结构中,两函数完全一样 TElemType Nil = ' '; // 设空为字符型的空格符 // 构造空二叉树T。因为T是固定数组,不会改变,故不需要& int InitBiTree(SqBiTree T) { int i; for(i=0;i<MAX_TREE_SIZE;i++) T[i]=Nil; // 初值为空 return 1; } void DestroyBiTree() { // 由于SqBiTree是定长类型,无法销毁 } // 按层序次序输入二叉树中结点的值(字符型或整型), 构造顺序存储的二叉树T int CreateBiTree(SqBiTree T) { int i = 0, l; char s[MAX_TREE_SIZE]; printf("请按层序输入结点的值(字符),空格表示空结点,结点数≤%d:\n", MAX_TREE_SIZE); printf("例如:abcefgh\n"); gets(s); // 输入字符串 l = strlen(s); // 求字符串的长度 for(;i<l;i++) // 将字符串赋值给T { T[i]=s[i]; // 此结点(不空)无双亲且不是根,T[(i+1)/2-1] == Nil表示T[i]无双亲 if(i!=0 && T[(i+1)/2-1] == Nil && T[i] != Nil) { printf("出现无双亲的非根结点%c\n",T[i]); exit(0); } } for(i=l;i<MAX_TREE_SIZE;i++) // 将空赋值给T的后面的结点 T[i]=Nil; return 1; } // 若T为空二叉树,则返回1,否则0 int BiTreeEmpty(SqBiTree T) { if(T[0]==Nil) // 根结点为空,则树空 return 1; else return 0; } // 返回T的深度 int BiTreeDepth(SqBiTree T) { int i,j=-1; for(i=MAX_TREE_SIZE-1;i>=0;i--) // 找到最后一个结点 if(T[i] != Nil) break; i++; // 为了便于计算 do j++; while(i>=pow(2,j)); //i > pow(2, depth-1) && i <= pow(2, depth) return j; //j = depth; } // 当T不空,用e返回T的根,返回1;否则返回0,e无定义 int Root(SqBiTree T,TElemType *e) { if(BiTreeEmpty(T)) // T空 return 0; else { *e=T[0]; return 1; } }
// 返回处于位置e(层,本层序号)的结点的值 TElemType Value(SqBiTree T,position e) { // 将层、本层序号转为矩阵的序号 return T[((int)pow(2,e.level-1) - 1) + (e.order - 1)]; // ((int)pow(2,e.level-1) - 1)为该e.level的结点个数, // (e.order - 1)为本层的位置 }
// 给处于位置e(层,本层序号)的结点赋新值value int Assign(SqBiTree T,position e,TElemType value) { // 将层、本层序号转为矩阵的序号 int i = (int)pow(2,e.level-1) + e.order - 2; if(value != Nil && T[(i+1)/2-1] == Nil) // 叶子非空值但双亲为空 return 0; else if(value == Nil && (T[i*2+1] != Nil || T[i*2+2] != Nil)) // 双亲空值但有叶子(不空) return 0; T[i]=value; return 1; }
// 若e是T的非根结点,则返回它的双亲,否则返回"空" TElemType Parent(SqBiTree T,TElemType e) { int i; if(T[0]==Nil) // 空树 return Nil; for(i=1;i<=MAX_TREE_SIZE-1;i++) if(T[i]==e) // 找到e return T[(i+1)/2-1]; return Nil; // 没找到e }
// 返回e的左孩子。若e无左孩子,则返回"空" TElemType LeftChild(SqBiTree T,TElemType e) { int i; if(T[0]==Nil) // 空树 return Nil; for(i=0;i<=MAX_TREE_SIZE-1;i++) if(T[i]==e) // 找到e return T[i*2+1]; return Nil; // 没找到e }
// 返回e的右孩子。若e无右孩子,则返回"空" TElemType RightChild(SqBiTree T,TElemType e) { int i; if(T[0]==Nil) // 空树 return Nil; for(i=0;i<=MAX_TREE_SIZE-1;i++) if(T[i]==e) // 找到e return T[i*2+2]; return Nil; // 没找到e }
// 返回e的左兄弟。若e是T的左孩子或无左兄弟,则返回"空" TElemType LeftSibling(SqBiTree T,TElemType e) { int i; if(T[0]==Nil) // 空树 return Nil; for(i=1;i<=MAX_TREE_SIZE-1;i++) if(T[i] == e && i%2 == 0) // 找到e且其序号为偶数(是右孩子) return T[i-1]; return Nil; // 没找到e }
// 返回e的右兄弟。若e是T的右孩子或无右兄弟,则返回"空" TElemType RightSibling(SqBiTree T,TElemType e) { int i; if(T[0]==Nil) // 空树 return Nil; for(i=1;i<=MAX_TREE_SIZE-1;i++) if(T[i]==e&&i%2) // 找到e且其序号为奇数(是左孩子) return T[i+1]; return Nil; // 没找到e }
// 把从q的j结点开始的子树移为从T的i结点开始的子树 // InsertChild()用到 void Move(SqBiTree q,int j,SqBiTree T,int i) { if(q[2*j+1] != Nil) // q的左子树不空 Move(q,(2*j+1),T,(2*i+1)); // 把q的j结点的左子树移为T的i结点的左子树 if(q[2*j+2] != Nil) // q的右子树不空 Move(q,(2*j+2),T,(2*i+2)); // 把q的j结点的右子树移为T的i结点的右子树 T[i]=q[j]; // 把q的j结点移为T的i结点 q[j]=Nil; // 把q的j结点置空 }
// 根据LR为0或1,插入c为T中p结点的左或右子树。p结点的原有左或 // 右子树则成为c的右子树 int InsertChild(SqBiTree T,TElemType p,int LR,SqBiTree c) { int j,k,i=0; for(j=0;j<(int)pow(2,BiTreeDepth(T))-1;j++) // 查找p的序号 if(T[j]==p) // j为p的序号 break; k=2*j+1+LR; // k为p的左或右孩子的序号 if(T[k] != Nil) // p原来的左或右孩子不空 Move(T,k,T,2*k+2); // 把从T的k结点开始的子树移为从k结点的右子树开始的子树 Move(c,i,T,k); // 把从c的i结点开始的子树移为从T的k结点开始的子树 return 1; }
// 构造一个空队列Q int InitQueue(SqQueue *Q) { (*Q).base=(QElemType *)malloc(MAXQSIZE*sizeof(QElemType)); //分配定长的空间,相当于一个数组 if(!(*Q).base) // 存储分配失败 exit(0); (*Q).front=(*Q).rear=0; //初始化下标 return 1; }
// 插入元素e为Q的新的队尾元素 int EnQueue(SqQueue *Q,QElemType e) { if((*Q).rear>=MAXQSIZE) { // 队列满,增加1个存储单元 (*Q).base=(QElemType *)realloc((*Q).base,((*Q).rear+1)*sizeof(QElemType)); if(!(*Q).base) // 增加单元失败 return 0; } *((*Q).base+(*Q).rear)=e; (*Q).rear++; return 1; }
// 若队列不空,则删除Q的队头元素,用e返回其值,并返回1,否则返回0 int DeQueue(SqQueue *Q,QElemType *e) { if((*Q).front==(*Q).rear) // 队列空 return 0; *e=(*Q).base[(*Q).front]; (*Q).front=(*Q).front+1; return 1; }
// 根据LR为1或0,删除T中p所指结点的左或右子树 int DeleteChild(SqBiTree T,position p,int LR) { int i; int k=1; // 队列不空的标志 SqQueue q; InitQueue(&q); // 初始化队列,用于存放待删除的结点 i=(int)pow(2,p.level-1)+p.order-2; // 将层、本层序号转为矩阵的序号 if(T[i]==Nil) // 此结点空 return 0; i=i*2+1+LR; // 待删除子树的根结点在矩阵中的序号 while(k) { if(T[2*i+1]!=Nil) // 左结点不空 EnQueue(&q,2*i+1); // 入队左结点的序号 if(T[2*i+2]!=Nil) // 右结点不空 EnQueue(&q,2*i+2); // 入队右结点的序号 T[i]=Nil; // 删除此结点 k=DeQueue(&q,&i); // 队列不空 } return 1; }
int(*VisitFunc)(TElemType); // 函数变量
void PreTraverse(SqBiTree T,int e) { // PreOrderTraverse()调用 VisitFunc(T[e]); //先调用函数VisitFunc处理根 if(T[2*e+1]!=Nil) // 左子树不空 PreTraverse(T,2*e+1); //然后处理左子树 if(T[2*e+2]!=Nil) // 右子树不空 PreTraverse(T,2*e+2); }
// 先序遍历T,对每个结点调用函数Visit一次且仅一次。 int PreOrderTraverse(SqBiTree T,int(*Visit)(TElemType)) { VisitFunc=Visit; if(!BiTreeEmpty(T)) // 树不空 PreTraverse(T,0); printf("\n"); return 1; }
// InOrderTraverse()调用 void InTraverse(SqBiTree T,int e) { if(T[2*e+1]!=Nil) // 左子树不空 InTraverse(T,2*e+1); VisitFunc(T[e]); if(T[2*e+2]!=Nil) // 右子树不空 InTraverse(T,2*e+2); }
// 中序遍历T,对每个结点调用函数Visit一次且仅一次。 int InOrderTraverse(SqBiTree T,int(*Visit)(TElemType)) { VisitFunc=Visit; if(!BiTreeEmpty(T)) // 树不空 InTraverse(T,0); printf("\n"); return 1; }
// PostOrderTraverse()调用 void PostTraverse(SqBiTree T,int e) { if(T[2*e+1]!=Nil) // 左子树不空 PostTraverse(T,2*e+1); if(T[2*e+2]!=Nil) // 右子树不空 PostTraverse(T,2*e+2); VisitFunc(T[e]); }
// 后序遍历T,对每个结点调用函数Visit一次且仅一次。 int PostOrderTraverse(SqBiTree T,int(*Visit)(TElemType)) { VisitFunc = Visit; if(!BiTreeEmpty(T)) // 树不空 PostTraverse(T,0); printf("\n"); return 1; }
// 层序遍历二叉树 void LevelOrderTraverse(SqBiTree T,int(*Visit)(TElemType)) { int i=MAX_TREE_SIZE-1,j; while(T[i] == Nil) i--; // 找到最后一个非空结点的序号 for(j=0;j<=i;j++) // 从根结点起,按层序遍历二叉树 if(T[j] != Nil) Visit(T[j]); // 只遍历非空的结点 printf("\n"); }
// 逐层、按本层序号输出二叉树 void Print(SqBiTree T) { int j,k; position p; TElemType e; for(j=1;j<=BiTreeDepth(T);j++) { printf("第%d层: ",j); for(k=1; k <= pow(2,j-1);k++) { p.level=j; p.order=k; e=Value(T,p); if(e!=Nil) printf("%d:%c ",k,e); } printf("\n"); } }
int visit(TElemType e) { printf("%c ",e); return 0; }
int main() { int i,j; position p; TElemType e; SqBiTree T,s; InitBiTree(T); CreateBiTree(T); printf("建立二叉树后,树空否?%d(1:是 0:否) 树的深度=%d\n", BiTreeEmpty(T),BiTreeDepth(T)); i=Root(T,&e); if(i) printf("二叉树的根为:%c\n",e); else printf("树空,无根\n"); printf("层序遍历二叉树:\n"); LevelOrderTraverse(T,visit); printf("中序遍历二叉树:\n"); InOrderTraverse(T,visit); printf("后序遍历二叉树:\n"); PostOrderTraverse(T,visit); printf("请输入待修改结点的层号 本层序号: "); scanf("%d%d%*c",&p.level,&p.order); e=Value(T,p); printf("待修改结点的原值为%c请输入新值: ",e); scanf("%c%*c",&e); Assign(T,p,e); printf("先序遍历二叉树:\n"); PreOrderTraverse(T,visit); printf("结点%c的双亲为%c,左右孩子分别为",e,Parent(T,e)); printf("%c,%c,左右兄弟分别为",LeftChild(T,e),RightChild(T,e)); printf("%c,%c\n",LeftSibling(T,e),RightSibling(T,e)); InitBiTree(s); printf("建立右子树为空的树s:\n"); CreateBiTree(s); printf("树s插到树T中,请输入树T中树s的双亲结点 s为左(0)或右(1)子树: "); scanf("%c%d%*c",&e,&j); InsertChild(T,e,j,s); Print(T); printf("删除子树,请输入待删除子树根结点的层号 本层序号 左(0)或右(1)子树: "); scanf("%d%d%d%*c",&p.level,&p.order,&j); DeleteChild(T,p,j); Print(T); ClearBiTree(T); printf("清除二叉树后,树空否?%d(1:是 0:否) 树的深度=%d\n", BiTreeEmpty(T),BiTreeDepth(T)); i=Root(T,&e); if(i) printf("二叉树的根为:%c\n",e); else printf("树空,无根\n"); system("pause"); return 0; }
/* 输出效果:
请按层序输入结点的值(字符),空格表示空结点,结点数≤100: 例如:abcefgh abcdefgh 建立二叉树后,树空否?0(1:是 0:否) 树的深度=4 二叉树的根为:a 层序遍历二叉树: a b c d e f g h 中序遍历二叉树: h d b e a f c g 后序遍历二叉树: h d e b f g c a 请输入待修改结点的层号 本层序号: 3 2 待修改结点的原值为e请输入新值: i 先序遍历二叉树: a b d h i c f g 结点i的双亲为b,左右孩子分别为 , ,左右兄弟分别为d, 建立右子树为空的树s: 请按层序输入结点的值(字符),空格表示空结点,结点数≤100: 例如:abcefgh jk l 树s插到树T中,请输入树T中树s的双亲结点 s为左(0)或右(1)子树: i 0 第1层: 1:a 第2层: 1:b 2:c 第3层: 1:d 2:i 3:f 4:g 第4层: 1:h 3:j 第5层: 5:k 第6层: 9:l 删除子树,请输入待删除子树根结点的层号 本层序号 左(0)或右(1)子树: 2 1 0 第1层: 1:a 第2层: 1:b 2:c 第3层: 2:i 3:f 4:g 第4层: 3:j 第5层: 5:k 第6层: 9:l 清除二叉树后,树空否?1(1:是 0:否) 树的深度=0 树空,无根 请按任意键继续. . . */ | |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: **** 队列实现 **** 周日 十一月 25, 2012 7:11 pm | |
| #include <stdlib.h> #include <stdio.h> #define TRUE 1 #define ERROR 0 #define FALSE 0 #define OK 1 #define OVERFLOW -2 typedef int Status; typedef struct QNode { QElemType data; struct QNode *next; }QNode,*QueuePtr;
typedef struct { QueuePtr front,rear; }LinkQueue;
Status InitQueue(LinkQueue &Q) {Q.front=Q.rear=(QNode*)malloc(sizeof(QNode)); if (!Q.front) exit(OVERFLOW); Q.front->next=NULL; return OK; }
Status DestroyQueue(LinkQueue &Q) {while (Q.front) { Q.rear=Q.front->next; free(Q.front); Q.front=Q.rear; } return OK; }
Status ClearQueue(LinkQueue &Q) {while (Q.front->next) { Q.rear=Q.front->next; Q.front->next=Q.front->next->next; free(Q.rear); } return OK; }
Status QueueEmpty(LinkQueue Q) {if (Q.front->next==NULL) return OK; else return FALSE; }
Status QueueLength(LinkQueue Q) {QNode *p=Q.front; int len=0; while(p->next) {len++;p=p->next;} return len; } Status GetHead(LinkQueue Q,QElemType &e) {if (Q.front->next==NULL) return FALSE; e=Q.front->next->data; return OK; } Status EnQueue(LinkQueue &Q, QElemType e ) { QNode *p=(QNode*)malloc(sizeof(QNode)); p->data = e; p->next = NULL; Q.rear->next = p; //入队 Q.rear =p; return OK; } Status DeQueue(LinkQueue &Q, QElemType &e ) { QNode *p; //删去队头结点,并返回队头元素的值 if ( QueueEmpty (Q) ) return ERROR; //判队空 p = Q.front->next; e= p->data; //保存队头的值 Q.front->next=p->next; //新队头 if (Q.rear==p) Q.rear=Q.front; free (p); return OK; } /*void print(QElemType c) { printf("%c ",c->data); } Status QueueTraverse(LinkQueue Q,void (*vi)(QElemType)) { QNode *p= Q.front; int i; while (p->next) {p=p->next; vi(p->data); } printf("\n"); return OK; }*/ | |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: 两个线性表的合并问题 周三 十一月 07, 2012 6:42 pm | |
| #include "linklist.h" void creatlist(LinkList &l) { int num,e,i; initlist(l); printf("请输入表长度:\n"); scanf("%d",&num); if (num==0) printf("创建的是空表:"); else {for (i=1;i<=num;i++) {printf("请输入表中第%d个元素值:\n",i); scanf("%d",&e); listinsert(l,i,e); } } ListTraverse(l,print); } void chaji(LinkList &la,LinkList lb) { int la_len,lb_len; int i,j; ElemType e; lb_len=listlength(lb); for(i=1;i<=lb_len;i++) { getelem(lb,i,e); la_len=listlength(la); if (la_len) { j=LocateElem(la,e,equal); if (j) listdelete(la,j,e); } else {printf("the la list is empthy\n");exit (0);} } printf("A-B的结果:\n"); ListTraverse(la,print); } void main() { LNode la,lb,lc,*l1=&la,*l2=&lb; int j,i,e,num; for (; { printf("请输入操作选择:\n"); printf("1:创建线性表\n"); printf("2:集合差运算\n"); printf("3:集合并运算\n"); printf("4:纯集合运算\n"); printf("0:退出系统\n"); scanf("%d",&i); switch(i) {case 1:creatlist(l1);ListTraverse(l1,print);break; case 2:printf("请输入la表信息:\n"); creatlist(l1); printf("请输入lb表信息:\n"); creatlist(l2); chaji(l1,l2); break; /*case 3:printf("请输入la表信息:\n"); creatlist(la); printf("请输入lb表信息:\n"); creatlist(lb); Union(la,lb); printf("合并后的结果:\n"); ListTraverse(la,print); break; case 4:printf("请输入la表信息:\n"); creatlist(la); chunji(la,lb); break;*/ } if (!i) break; } } | |
| | | 让一切随风 Admin
帖子数 : 257 注册日期 : 12-11-03 年龄 : 32 地点 : 湖南
| 主题: 线性表的顺序表示和实现 周三 十一月 07, 2012 6:39 pm | |
| /*线性表的顺序表示和实现*/ #include<stdio.h> #include<stdlib.h> #include<malloc.h> typedef int status; typedef int ElemType; #define TRUE 1 #define ERROR 0 #define FALSE 0 #define OK 1 #define OVERFLOW -2 #define list_init_size 100 #define listincrement 10 typedef struct{ ElemType *elem; int length; int listsize; }sqlist; status equal(ElemType a,ElemType b) {if(a==b) return TRUE; else return FALSE; } status initlist(sqlist &l){ l.elem=(ElemType*)malloc(list_init_size*sizeof(ElemType)); if(!l.elem) exit(OVERFLOW); l.length=0; l.listsize=list_init_size; return OK; } status destroy(sqlist &l) {if (l.elem) free(l.elem); return OK; } status clearlist(sqlist &l) {l.length=0; return OK; } int listlength(sqlist l) { return l.length;} status listempty(sqlist l) { return !(l.length);} status getelem(sqlist l,int i,ElemType &e) { if(i<1||i>l.length) exit(ERROR); e=*(l.elem+i-1); return OK; } int LocateElem(sqlist L,ElemType e,status(*compare)(ElemType,ElemType)) { ElemType *p; int i=1; p=L.elem; while(i<=L.length&&!(*compare)(*p++,e)) ++i; if(i<=L.length) return i; else return 0; } status listinsert(sqlist &l,int i,ElemType e) { ElemType *newbase,*q,*p; if(i<1||i>l.length+1) return ERROR; if(l.length>=l.listsize){ newbase=(ElemType*)realloc(l.elem,(l.listsize+listincrement)*sizeof(ElemType)); if(!newbase) exit(OVERFLOW); l.elem=newbase; l.listsize+=listincrement; } q=&(l.elem[i-1]); for(p=&(l.elem[l.length-1]);p>=q;--p) *(p+1)=*p; *q=e; ++l.length; return OK; } status listdelete(sqlist &l,int i,ElemType &e) { ElemType *newbase,*q,*p; if(i<1||i>l.length) return ERROR; q=&(l.elem[i]); for(p=q;p<=&(l.elem[l.length-1]);p++) *(p-1)=*p; e=*q; -- l.length; return OK; } void print(ElemType c) { printf("%d ",c); } status ListTraverse(sqlist l,void(*vi)(ElemType)) { ElemType *p; int i; p=l.elem; for(i=1;i<=l.length;i++) vi(*p++); printf("\n"); return OK; }
| |
| | | | ****数据结构**** | |
|
| |