链表相关——单链表的操作

#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>

typedef int ElemType;  //定义数据类型
typedef struct node
{
    ElemType data;   //数据域
    struct node * next; //指针域
}slink;  //单链表类型名

slink *creslink(int n) //创建带头结点的单链表
{
    slink *head,*p,*s;//创建头结点
    int i;
    p=head=(slink *)malloc(sizeof (slink));
    for(i=1;i<=n;i++)
    {
        s=(slink *)malloc(sizeof(slink));//申请空间
        scanf("%d",&s->data);
        p->next=s;
        p=s;
    }
    p->next=NULL;  //尾结点的指针一定要置空
    return head;
}

int getlen(slink *head) //获取表长
{
    slink * p;
    int n=0;
    p=head->next;
    while(p!=NULL)
    {
        n++;
        p=p->next;
    }
    return n;
}
int getelem(slink *head,int i,ElemType * e)//取元素操作
{
    slink *p;
    int j;
    if(i<1) //参数1,不合法,返回0
    return 0;
    p=head->next;
    j=1;
    while(p!=NULL&&j<i)  //从第1个头结点开始查找
    {
        p=p->next;
        j++;
    }
    if(p==NULL)
    return 0;
    * e=p->data;
    return 1;
}
slink * locate(slink * head,ElemType x) //定位操作
{
    int i;
    slink *p;
    p=head->next;
    i=1;
    while(p!=NULL&&p->data!=x)
    {
        p=p->next;
        i++;
    }
    return p;
}
int delete(slink * head,int x) //删除操作
{
    slink *p,*q;
    p=head;
    while(p->next!=NULL&&x!=p->next->data)
   {
    p=p->next;
   }
   if(p->next==NULL)
    return 0;
   q=p->next; //q指向第i个结点
   p->next=q->next; //p的指针与指向结点q指向结点的下一个结点,删除第i个结点
   free(q);
   return 1;
}
int insert(slink * head,int i,ElemType x)
{
    slink *p,*q;
    int j;
    if(i<1)
    return 0;
    p=head;
    j=0;
    while(p!=NULL&&j<i-1)
    {
        p=p->next;
        j++;
    }
    if(p==NULL)
        return 0;
    q=(slink *)malloc(sizeof(slink));
    q->data=x;
    q->next=p->next;
    p->next=q;
    return 1;
}
void Print(slink *head)  //打印单链表
{
    slink *p;
    p=head->next;
    while(p!=NULL)
    {
        printf("%4d",p->data);
        p=p->next;
    }
    printf("\n");

}
int main()
{
    slink *head;
    ElemType *e;
    head=creslink(10);
    Print(head);
    delete(head,4);
    Print(head);
    return 0;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值