数据结构顺序表操作示例
作者:
#include<stdio.h>
#include<malloc.h>
#define maxsize 1024
typedef char datatype;
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
/*在第I个元素前插入数据x,元素从0开始计数*/
int insert(sequenlist *L,datatype x,int i)
{
int j;
if(L->last==maxsize-1)
{
printf("overflow");
return 0;
}
else if((i<0)||(i>L->last))
{
printf("error,please input the right 'i'");
return 0;
}
else
{
for(j=L->last;j>=i;j--)
{
L->data[j+1]=L->data[j];
L->data[i]=x;
L->last=L->last +1;
}
}
return(1);
}
/*删除第i个元素,元素从0开始计数*/
int dellist(sequenlist *L,int i)
{
if((i<0)||(i>L->last))
{printf("error,please input the right 'i'");
return 0;}
else
{
for(;i<L->last ;i++)
L->data[i]=L->data[i+1];
L->last =L->last-1;
return(1);
}
}
/*建立顺序表,其元素为单个字符*/
void createlist(sequenlist *L)
{
int n,i;
char tmp;
printf("请输入元素个数:\n");
scanf("%d",&n);
for(i=0;i<n;i++)
{
printf("data[%d]=",i);
fflush(stdin);
scanf("%c",&tmp);
L->data[i] =tmp;
}
L->last=n-1;
printf("/n");
}
/*打印顺序表*/
void printflist(sequenlist *L)
{
int i;
for(i=0;i<L->last ;i++)
{
printf("data[%d]=",i);
printf("%c\n",L->data [i]);
}
}
main()
{
sequenlist *L;
char cmd,x;
int i;
L=(sequenlist *)malloc(sizeof(sequenlist)); /*指针在使用前初始化*/
createlist(L);
printflist(L);
do
{
printf("i,I...插入\n");
printf("d,D...删除\n");
printf("q,Q...退出\n");
do
{
fflush(stdin);
scanf("%c",&cmd);
}while((cmd!='d')&&(cmd!='D')&&(cmd!='q')&&(cmd!='Q')&&(cmd!='i')&&(cmd!='I'));
switch(cmd)
{
case 'i':
case 'I':
printf("请输入你要插入的数据:");
fflush(stdin);
scanf("%c",&x);
printf("请输入你要插入的位置:");
scanf("%d",&i);
insert(L,x,i);
printflist(L);
break;
case 'd':
case 'D':
printf("请输入你要删除的元素的位置:");
fflush(stdin);
scanf("%d",&i);
dellist(L,i);
printflist(L);
break;
}
}while((cmd!='q')&&(cmd!='Q'));
}
您可能感兴趣的文章:
- python实现bitmap数据结构详解
- java数据结构和算法学习之汉诺塔示例
- LinkedList学习示例模拟堆栈与队列数据结构
- C数据结构之双链表详细示例分析
- C数据结构之单链表详细示例分析
- 从数据结构的角度分析 for each in 比 for in 快的多
- 数据结构课程设计- 解析最少换车次数的问题详解
- 数据结构课程设计-用栈实现表达式求值的方法详解
- 解析从源码分析常见的基于Array的数据结构动态扩容机制的详解
- C++ 冒泡排序数据结构、算法及改进算法
- 从数据结构分析看:用for each...in 比 for...in 要快些
- C#数据结构之循环链表的实例代码
- Oracle 11g Release (11.1) 索引底层的数据结构
- C#数据结构与算法揭秘五 栈和队列
- C#数据结构与算法揭秘四 双向链表
- C#数据结构与算法揭秘三 链表
- C#数据结构与算法揭秘二 线性结构
- C#数据结构与算法揭秘一