标签:遍历 序号 scan size 删除 scanf ase str 数据
#include<stdio.h>
#include<stdlib.h>
typedef int Data;
typedef struct st
{
Data data;
struct st *prior,*next;
}Link;
int i=0;
void menu()
{
printf("----------------------\n");
printf("0.退出 \n");
printf("1.初始化双链表(带头)\n");
printf("2.清空链表\n");
printf("3.表长\n");
printf("4.头插法 \n");
printf("5.尾插法 \n");
printf("6.插入 \n");
printf("7.删除 \n");
printf("8.遍历 \n");
printf("----------------------\n");
}
void csh(Link* &L)//初始化
{
L=(Link*)malloc(sizeof(Link));
L->prior=L->next=NULL;
printf("初始化成功!\n");
}
void qk(Link* &L )//清空
{
Link *p=L->next,*q=p->next;
L->next=L->prior=NULL;
while(q!=NULL)
{
free(p);
p=q;q=q->next;
--i;
}
free(p);
printf("链表销毁完成\n");
}
void bc(Link* L)//表长
{
int i=0;
Link *p=L->next;
while(p)
{
i++;
p=p->next;
}
printf("表长为:%d\n",i);
}
void tc(Link* L)//头插法
{
Link *p,*m;
p=L;
printf("输入-1退出\n");
while(1)
{
m=(Link*)malloc(sizeof(Link));
printf("请输入第%d个数\n",i+++1);
scanf("%d",&m->data);
if(m->data!=-1)
{
if(p->next==NULL)
{
m->next=p->next;
p->next=m;
m->prior=p;
}
else
{
m->next=p->next;
p->next->prior=m;
p->next=m;
m->prior=p;
}
}
else {--i;return;}
}
}
void wc(Link *L)//尾插
{
Link *p,*m;
p=L;
printf("输入-1退出\n");
while(1)
{
m=(Link*)malloc(sizeof(Link));
printf("请输入第%d个数\n",i+++1);
scanf("%d",&m->data);
if(m->data!=-1)
{
p->next=m;
m->prior=p;
p=m;
}
else
{
p->next=NULL;
--i;
return;
}
}
}
void cr(Link *L)//插入
{
Link *p=L->next,*m;
int js=0,j;
m=(Link*)malloc(sizeof(Link));
printf("输入要插入的位置:");
scanf("%d",&j);
printf("输入要插入的数据:");
scanf("%d",&m->data);
while(js<j)
{
p=p->next;
js++;
}
m->next=p->next;
m=p->next->prior;
p->next=m;
i++;
}
void sc(Link *L)//删除
{
Link *p,*q;
int x;
p=L->next;
printf("请输入要删除的数:\n");
scanf("%d",&x);b
while(p->data!=x)
{
q=p;
p=p->next;
}
p->next->prior=q;
q->next=p->next;
free(p);
--i;
}
void bl(Link *L) //遍历
{
Link *p=L->next,*q;
if(p==NULL) return ;
printf("链表为:\n");
while(p)
{
printf("%4d",p->data);
q=p;
p=p->next;
}
printf("\n");
printf("反序:\n");
while(q->prior)
{
printf("%4d",q->data);
q=q->prior;
}
printf("\n");
}
main()
{
Link *L;
int xh;
menu();
printf("请输入序号:\n");
scanf("%d",&xh);
while(1)
{
switch(xh)
{
case 0:return 0;
case 1:csh(L);break;
case 2:qk(L);break;
case 3:bc(L);break;
case 4:tc(L);break;
case 5:wc(L);break;
case 6:cr(L);break;
case 7:sc(L);break;
case 8:bl(L);break;
default:
{
printf("请重新输入!\n");
scanf("%d",&xh);
continue;
}
}
menu();
printf("请输入序号:\n");
scanf("%d",&xh);
}
}
标签:遍历 序号 scan size 删除 scanf ase str 数据
原文地址:https://www.cnblogs.com/Qinghua99/p/10828082.html