重学数据结构:单链表的各种操作(C语言)

单链表的定义

typedef struct LNode
{
   struct  LNode *next;
   int data;
}LNode,*LinkList;

头插法建立链表(带头节点)

LinkList link_HeadInsert()
{
   LinkList head=(LinkList)malloc(sizeof(LinkList));
   head->next=NULL;
   int data;
   scanf("%d",&data);
   while(data!=9999)
   {
       LNode *node=(LNode *)malloc(sizeof(LNode));
       node->data=data;
	   node->next=head->next;
       head->next=node;
	   scanf("%d",&data);
   }
   return head;
}

尾插法建立链表(带头节点)

LinkList link_TailInsert()
{
   LinkList head=(LinkList)malloc(sizeof(LinkList));
   head->next=NULL;
   LNode *prenode=head;
   int data;
   scanf("%d",&data);
   int i=0;
   while(data!=9999)
   {  
	   LNode *node=(LNode *)malloc(sizeof(LNode));
	   node->data=data;
	   node->next=NULL;
	   if(i==0)
	   {
		   head->next=node;
	   }
	   else
	   {
	       prenode->next=node;
	   }
	    prenode=node;
	   scanf("%d",&data);
	   i++;
   }
   return head;
}

头插法建立链表(不带头节点)

LinkList link_HeadInsert_WithoutHead()
{
   LinkList head=(LinkList)malloc(sizeof(LinkList));
   int i=0;
   int data;
   scanf("%d",&data);
   while(data!=9999)
   {
	   LNode *node=(LNode *)malloc(sizeof(LNode));
       node->data=data;
	   if(i==0)
	   {
		   node->next=NULL;
	   }
	   else
	   {
	        node->next=head;
	   }
	   head=node;
	   i++;
	   scanf("%d",&data);
   }
   return head;
}

按位序插入(带头节点)

Status linkListInsert(LinkList L,int i,int e)
{
	int result=-1;
	if(i<1)return result;
   	LNode *node=L;
	int j=0;
	while(node!=NULL&&j<i-1)
	{
		node=node->next;
	    j++;    
	}
	if(node!=NULL)
	{
		LNode *newNode=(LNode *)malloc(sizeof(LNode));
		newNode->data=e;
		newNode->next=node->next;
		node->next=newNode;
	}
    return result;
}

按位序插入(不带头节点)

LinkList linkListInsert_WithoutHead(LinkList &L,int i,int e)
{
	if(i<1)return NULL;

    if(i==1)
	{
    	LNode *newNode=(LNode *)malloc(sizeof(LNode));
		newNode->data=e;
		newNode->next=L;
		L=newNode;
	}
	else
	{
		LNode *node=L;
	   	int j=1;
		while(node!=NULL&&j<i-1)
		{
			node=node->next;
			j++;    
		}
		if(node!=NULL)
		{
			LNode *newNode=(LNode *)malloc(sizeof(LNode));
			newNode->data=e;
			newNode->next=node->next;
			node->next=newNode;
		}
	}
    	return L;
}

指定节点的后插操作1

void InsertNextNode(LNode *p,int e)
{
     LNode *newNode=(LNode *)malloc(sizeof(LNode));
	 if(newNode!=NULL)
	 {
	     newNode->data=e;
		 newNode->next=p->next;
		 p->next=newNode;
	 }
}

指定节点的后插操作2

void InsertNextNode(LinkList &L,int i,int e)
{
      LNode *node=L;
	  int j=0;
	  while(node!=NULL&&j<i-1)
	  {
	      node=node->next;
	  }
	  if(node!=NULL)
	  {
		  InsertNextNode(node,e);
	     /* 相当于InsertNextNode(node,e);
		 LNode *newNode=(LNode *)malloc(sizeof(LNode));
		 if(newNode!=NULL)
		 {
			 newNode->data=e;
			 newNode->next=node->next;
			 node->next=newNode;
		 }*/
	  }
}

指定节点的前插操作(第一次没想到)

void InsertPriorNode(LNode *p,int e)
{
    if(p!=NULL)
	{
	    LNode *newNode=(LNode *)malloc(sizeof(LNode));
		newNode->next=p->next;
		p->next=newNode;
		newNode->data=p->data;
		p->data=e;
	}
}

按位序删除元素

void linkListDelete(LinkList &L,int i,int &e)
{
    if(i<0)return;
	int j=0;
	LNode *node=L;
	while(node!=NULL&&j<i-1)
	{
	    node=node->next;
		j++;
	}
	if(node==NULL)return; //没找到
	if(node->next==NULL) return; //没了
	
	if(node!=NULL)
	{
	    LNode *p=node->next;
		node->next=p->next;
		e=p->data;
		free(p);
	}
}

删除指定节点(第一次没想到)

void DeleteNode(LNode *p)
{
    if(p==NULL)return;
    LNode *q=p->next; //p的下一个节点
    p->data=q->data;
	p->next=q->next;
	free(q);

}

根据位序查找数值

int getElem(LinkList L,int i)
{
	int result=-1;
	if(i<1)return result;
   	LNode *node=L->next;
	int j=0;
	while(node!=NULL&&j<i-1)
	{
		node=node->next;
		result=node->data;
	    j++;    
	}
	return result;
}

打印(有头结点)

void printLinkList(LinkList L)
{
	int i=1;
	LNode *node=L->next;
    while(node!=NULL)
	{
	    printf("第%d位:%d\n",i,node->data);
		node=node->next;
		i++;
	}
}

打印(没有头结点)

void printLinkList_WithoutHead(LinkList L)
{
	int i=1;
		//printf("L:%p\n",L);
	LNode *node=L;
    while(node!=NULL)
	{
	    printf("第%d位:%d\n",i,node->data);
		node=node->next;
		i++;
	}
}

测试方法

int main(int argc, char* argv[])
{
	//LinkList L=link_HeadInsert();
	//printLinkList(L);
    //int r=getElem(L,3);
	//printf("getElem(L,3)=%d\n",r);
	//printf("执行linkListInsert(L,3,99)后\n");
	//linkListInsert(L,3,99);
  	//printLinkList(L);

    //LinkList L=link_HeadInsert_WithoutHead();
	//printLinkList_WithoutHead(L);
	//printf("linkListInsert_WithoutHead(L,3,99)后\n");
    //L=linkListInsert_WithoutHead(L,1,99);
	//linkListInsert_WithoutHead(L,3,99);
	//printLinkList_WithoutHead(L);

    //LinkList L = link_TailInsert();
    //printLinkList(L);
    //int e;
    //linkListDelete(L,3,e);
	//printf(" linkListDelete(L,3,e)删除的第3位是:%d\n",e);
	//printLinkList(L);

	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值