双向链表

#include <iostream>
#include <stdio.h> 
#include <stdlib.h>
typedef float ElemType;
typedef int Status;
typedef struct SXLNode{
	ElemType data;
	struct SXLNode *prior,*next;
}SXLNode,*SXLinkList;
//函数的声明
Status Creat_SX(SXLinkList &head);//双向链表的建立 
void Print_SX(SXLinkList head);//显示链表元素 
Status Insert_SX(SXLinkList &head,Status n,ElemType e);//双向链表的插入 
Status Delete_SX(SXLinkList &head,Status n);//双向链表的删除 






Status Creat_SX(SXLinkList &head)//双向链表的建立 
{
	SXLinkList q,p;
	Status i=0,j;
	head=(SXLinkList)malloc(sizeof(SXLNode));
	head->next=NULL;
	head->prior=NULL;
	p=head;
	
	scanf("%d",&j);
	
	for(i=0;i<j;i++)
	{
		q=(SXLinkList)malloc(sizeof(SXLNode));
		scanf("%f",&q->data);
		q->next=NULL;
		p->next=q;
		q->prior=p;
		p=q;
		
	}
	
	return 0;	
}
void Print_SX(SXLinkList head)//显示链表元素 
{
	SXLinkList q;
	q=head->next;
	
	while(q!=NULL)
	{
		printf("%4.2f ",q->data);
		q=q->next;
	} 
}
Status Insert_SX(SXLinkList &head,Status n,ElemType e)//双向链表的插入 
{
	SXLinkList p,q;
	Status i=1;
	p=head;
	
	while(p!=NULL&&i<n)
	{
		i++;
		p=p->next;
	} 
	q=(SXLinkList)malloc(sizeof(SXLNode));
	q->data=e;
	p->next->prior=q;
	q->next=p->next;
	p->next=q;
	q->prior=p;
	return 0;
}
Status Delete_SX(SXLinkList &head,Status n)//双向链表的删除 
{
	SXLinkList p,q;
	Status i=1;
	p=head;
	
	while(p->next!=NULL&&i<n-1)
	{
		i++;
		p=p->next;
	}
	q=p->next;
	q->next->prior=p;
	p->next=q->next;
	free(q);
} 


 
int main(int argc, char** argv) 
{
	SXLinkList head;
	ElemType e;
	
	//测试不规范请自己去测试发现错误请告知我 
	Creat_SX(head);//创建链表 
	Print_SX(head);//显示链表元素 
	printf("\n");
	printf("----------------------------\n");
	Insert_SX(head,1,0.3);
	Print_SX(head);//显示链表元素 
	printf("\n");
	printf("----------------------------\n");
	Delete_SX(head,1);
	Print_SX(head);//显示链表元素 
	return 0;
}

 

posted @ 2019-07-01 17:51  阳神  阅读(83)  评论(0编辑  收藏  举报