线性表 C语言实现

  

Linear_list.h

#ifndef   LINEAR_LIST_H
#define  LINEAR_LIST_H 
#include"Status.h"
#define  LIST_INIT_SIZE 100
#define LIST_INCREAMENT  10

typedef  int ElemType;


typedef  struct SqList
{
	ElemType  *elem;
	int length;
	int list_size;

	
}SqList,*Ptr;

//线性表的顺序存储

typedef  Ptr  SqListPtr;
 

 Status List_Init(SqListPtr  L);         //初始化线性表


 Status  List_Retrival(SqListPtr L, int pos, ElemType* elem);

 Status  List_Locate(SqListPtr L, ElemType  elem, int* pos);


 Status  List_Insert(SqListPtr L, ElemType elem, int pos);


 Status List_Delete(SqListPtr L,  int pos);




#endif

linear_list.cpp

#include "Linear_list.h"
#include"Linear_list.h"


//初始化线性表
Status List_Init(SqListPtr  L) {

	Status  S = S_SUCCESS;
	L->list_size = LIST_INIT_SIZE;
	L->length = 0;

	L->elem = (ElemType*)malloc(sizeof(ElemType) * L->list_size);
	if (L->elem == NULL)
	{
		return S_FAIL;
	}
	return S;
}

Status List_Retrival(SqListPtr L, int pos, ElemType* elem)
{
	Status  S = RANGE_ERROR;
	if (L)
	{
		if ((pos - 1) >= 0 && (pos - 1) < L->length)
		{
			*elem = L->elem[pos - 1];
			S = S_SUCCESS;
		}
	}
	else
	{
		S = S_FAIL
	}

	return S;

}

Status List_Locate(SqListPtr L, ElemType elem, int* pos)
{
	Status  S = RANGE_ERROR;

	if (L)
	{
		for (int i = 0; i < L->length; ++i)
		{
			if (L->elem[i] == elem)
			{
				*pos = i + 1;
				S = S_SUCCESS;
				break;
			}
		}
	}
	else
	{
		S = S_FAIL;
	}
	return S;
}

Status List_Insert(SqListPtr L, ElemType elem, int pos)
{

	Status  S = RANGE_ERROR;
	if ((pos-1)>0&&(pos-1)<L->length)
	{
		if (L&&L->length<L->list_size)
		{
			for (int i=L->length-1,i>=pos-1;--i)
			{
				L->elem[i + 1] = L->elem[i];
			}
			L->elem[pos - 1] = elem;
			L->length++;
			S = S_SUCCESS;
		}
	}
	else
	{
		S = S_FAIL;
	}

	return S;
}

Status List_Delete(SqListPtr L, int pos)
{
	Status  S = RANGE_ERROR;
	if ((pos-1)>0&&(pos-1)<L->length)
	{
		if (L&&L->length<L->list_size)
		{
			for (int i=pos-1;i<L->length;i++)
			{
				L->elem[i] = L->elem[i + 1];
			}
			L->length--;
			S = S_SUCCESS;
		}
	}
	else
	{
		S = S_FAIL;
	}
	return S;
}

List_node.h

#ifndef  LIST_NODE_H
#define   LIST_NODE_H
#include "Status.h"
typedef  ElemType  int;
typedef struct Node
{

	ElemType   elem;
	struct  Node* next;

}Node,*Ptr;
typedef  Ptr* SqListPtr;

Status  List_Retrieve(SqListPtr L, int pos, ElemType* elem);    //查找

Status  List_Locate(SqListPtr L,ElemType elem,int *pos);   //按值查找

Status  List_Insert(SqListPtr L, ElemType elem, int pos);

Status  List_Retrival(SqListPtr L, int pos, ElemType* elem);


Status List_Delete(SqListPtr L,  int pos);


#endif

List_node.cpp

#include "List_node.h"


Status List_Retrieve(SqListPtr L, int pos, ElemType* elem)
{
	Status  S = RANGE_ERROR;
	Ptr  p=(*L)->next;
	int i=1;
	while (p&&i<pos)
	{
		i++;
		p=p->next;
	}
	if (p&&i==pos)
	{
		*elem=p->elem;
		S=S_SUCCESS;
		/* code */
	}
	return S;
}
Status  List_Locate(SqListPtr L,ElemType elem,int *pos)   //°′?μ2é?ò
{

	Status  S = S_FAIL;
	Ptr  p=(*L)->next;
		int i=1;
		while (p)
		{
			if (p->elem==elem)
			{
				
				*pos=i;
				S=S_SUCCESS;
				break;
			}
			i++;
			p=p->next;
		}
	return S;
}


 Status  List_Insert(SqListPtr L, ElemType elem, int pos)
 {
	
	Status  S=RANGE_ERROR;
	Ptr   pHead=(*L);
	Ptr  pTemp;
	int i=1;
	while (pHead!=nullptr&&i<pos)
	{
		i++;
		pHead=pHead->next;
	}
	if (i==pos)
	{
		pTemp=pHead->next;
		if (pTemp)
		{
			Ptr  pElem=(Ptr)malloc(sizeof(Ptr));
			pHead->next=pElem;
			pElem->next=pTemp->next;
			S=S_SUCCESS;
		}
		else
			S=S_FAIL;
	}

	return  S;

 }


 Status List_Delete(SqListPtr L,  int pos)
 {
	Status  S=RANGE_ERROR;
	Ptr   pHead=(*L);
	Ptr  pTemp;
	int i=1;
	while (pHead!=nullptr&&i<pos)
	{
		i++;
		pHead=pHead->next;
	}
	if (i==pos)
	{
		pTemp=pHead->next;
		if (pTemp)
		{
			pHead->next=pTemp->next;
			delete  pTemp;
			S=S_SUCCESS;
		}
		else
			S=S_FAIL;
	}
	return S;
 }



Status  List_Retrival(SqListPtr L, int pos, ElemType* elem)
{
	Status  S=RANGE_ERROR;
	Ptr   pHead=(*L);
	int i=1;
	while (pHead!=nullptr&&i<pos)
	{
		i++;
		pHead=pHead->next;
	}
	if (i==pos)
	{
		*elem=pHead->elem;
		S=S_SUCCESS;
	}
	return  S;
}
相关文章