C语言实现顺序表基本操作汇总
来源:本站原创|时间:2020-01-10|栏目:C语言|点击: 次
本文汇总了C语言下实现及操作顺序表的方法,对于学习数据结构的朋友来说是一个不错的参考程序。完整代码如下:
#include<stdio.h> #include<stdlib.h> #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define LIST_INIT_SIZE 100 #define LISTINCREMENT 10 typedef int status ; typedef int ElemType ; typedef struct{ ElemType *elem; int length,listsize; }SqList; status InitList(SqList &L)//初始化 { L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize=LIST_INIT_SIZE; L.length=0; return OK; } status Build(SqList &L)//建立表 { int i,n; printf("请输入元素个数n和n个元素\n"); scanf("%d",&n); if(n>LIST_INIT_SIZE)//如果n大于当前空间 { L.elem=(ElemType *)realloc(L.elem,(n+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize=n+LISTINCREMENT; } for(i=0;i<n;i++) scanf("%d",L.elem+i); L.length=n; return OK; } void Print(SqList &L)//输出表中元素和长度 { int i; for(i=0;i<L.length;i++) printf("%d ",*(L.elem+i)); printf("\n长度为:%d\n\n",L.length); } void Tips()//提示函数 { printf("请选择你的想要的操作:\n"); printf("<1> 输出顺序表及顺序表的长度\n"); printf("<2> 删除值为x的结点\n"); printf("<3> 删除给定位置i的结点\n"); printf("<4> 将顺序表逆置\n"); printf("<5> 将顺序表按升序排序\n"); printf("<6> 将x插入到顺序表的适当位置上\n"); printf("<7> 将两个有序表合并\n"); printf("<0> 退出\n\n"); } status ListDelete1(SqList &L,int x)//删除值为X的元素 { int i; for(i=0;i<L.length;i++) if(*(L.elem+i)==x) break; if(i==L.length) return ERROR; for(i++;i<L.length;i++) *(L.elem+i-1)=*(L.elem+i); L.length--; return OK; } status ListDelete2(SqList &L,int x)//删除第X个元素 { int i; if(x<0||x>=L.length) return ERROR; for(i=x+1;i<L.length;i++) *(L.elem+i-1)=*(L.elem+i); L.length--; return OK; } void Inverse(SqList &L)//逆置函数 { int i,t; for(i=0;i<L.length/2;i++) { t=*(L.elem+i); *(L.elem+i)=*(L.elem+L.length-i-1); *(L.elem+L.length-i-1)=t; } } void Sort(SqList &L)//冒泡排序(升序) { int i,j,t; for(i=1;i<L.length;i++) for(j=0;j<L.length-i;j++) { if(*(L.elem+j)>*(L.elem+j+1)) { t=*(L.elem+j); *(L.elem+j)=*(L.elem+j+1); *(L.elem+j+1)=t; } } printf("已按升序排列\n\n"); } status ListInsert(SqList &L,int x)//将X插入,使仍然有序 { int i,k; if(L.length>=L.listsize) { L.elem=(ElemType *)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize+=LISTINCREMENT; } for(i=0;i<L.length;i++) if(x<*(L.elem+i)) break; k=i; for(i=L.length;i>k;i--) *(L.elem+i)=*(L.elem+i-1); *(L.elem+k)=x; L.length++; return OK; } status Merger(SqList &L,SqList &Lb)//合并两个线性表 { int i,j,k; SqList Lc; InitList(Lc); if(Lc.listsize<L.length+Lb.length) { Lc.elem=(ElemType *)realloc(Lc.elem,(L.length+Lb.length+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); Lc.listsize=L.length+Lb.length+LISTINCREMENT; } i=j=k=0; while(i<L.length && j<Lb.length) { if(*(L.elem+i) < *(Lb.elem+j)) { *(Lc.elem+k)=*(L.elem+i); k++;i++; } else { *(Lc.elem+k)=*(Lb.elem+j); k++;j++; } } while(i<L.length) { *(Lc.elem+k)=*(L.elem+i); k++;i++; } while(j<Lb.length) { *(Lc.elem+k)=*(Lb.elem+j); k++;j++; } Lc.length=L.length+Lb.length; L=Lc; return OK; } int main() { int op,x,flag; SqList L,Lb; InitList(L); Build(L); Tips(); scanf("%d",&op); while(op) { switch(op) { case 1: Print(L); break; case 2: printf("请输入要删除的数据X:\n"); scanf("%d",&x); flag=ListDelete1(L,x); if(flag) printf("删除成功!!\n\n"); else printf("元素不存在,删除失败!!\n\n"); break; case 3: printf("请输入要删除的位置i:\n"); scanf("%d",&x); flag=ListDelete2(L,x-1);//第i个元素对应的下标为i-1 if(flag) printf("删除成功!!\n\n"); else printf("元素不存在,删除失败!!\n\n"); break; case 4: Inverse(L); break; case 5: Sort(L); break; case 6: printf("请输入要插入的数据X:\n"); scanf("%d",&x); flag=ListInsert(L,x); if(flag) printf("插入成功!!\n\n"); else printf("插入失败!!\n\n"); break; case 7: printf("请输入Lb的内容:\n"); InitList(Lb); Build(Lb); flag=Merger(L,Lb); if(flag) printf("合并成功!!\n\n"); break; } Tips(); scanf("%d",&op); } return 0; }
栏 目:C语言
下一篇:VC实现屏幕截词功能的方法详解
本文标题:C语言实现顺序表基本操作汇总
本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/3591.html
您可能感兴趣的文章
- 04-02c语言函数调用后清空内存 c语言调用函数删除字符
- 04-02c语言的正则匹配函数 c语言正则表达式函数库
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言中对数函数的表达式 c语言中对数怎么表达
- 04-02c语言用函数写分段 用c语言表示分段函数
- 04-02c语言编写函数冒泡排序 c语言冒泡排序法函数
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段函数
- 04-02C语言中怎么打出三角函数 c语言中怎么打出三角函数的值
- 04-02c语言调用函数求fibo C语言调用函数求阶乘
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10SublimeText编译C开发环境设置
- 01-10C#中split用法实例总结
- 01-11ajax实现页面的局部加载
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 01-10delphi制作wav文件的方法
- 04-02jquery与jsp,用jquery