1.编程实现单链表的建立/测长/打印

typedef struct student
{
    int data;
    struct student *next;
}node;

node *creat()
{
    node *head, *p, *s;
    int x, cycle = 1;
    head = (node *)malloc(sizeof(head));
    p = head; //p指向尾部的结点
    while (cycle)
    {
        printf("\n please input the data: ");
        scanf("%d", &x);
        if (x != 0)
        {
            s = (node *)malloc(sizeof(node));
            s->data = x;
            printf("\n%d", s->data);
            p->next = s;
            p = s;
        }
        else cycle = 0;
    }
    head = head->next;
    p->next = NULL;
    return (head);
}

int length(node *head)
{
    node *p = head;
    int x = 0;
    while (p != NULL)
    {
        p = p->next;
        x++;
    }
    return x;
}

void print(node *head)
{
    node *p;int n;
    n = length(head);
    printf("\n Now ,these %d records are:\n", n);
    p = head;
    if (head != NULL)
        while (p != NULL)
        {
            printf("\n    %d", p->data);
            p = p->next;
        }
}

 

2.实现单链表的插入

node *insert(node *head, int num)
{
    node *p0, *p1, *p2 = NULL;
    p1 = head;
    p0 = (node *)malloc(sizeof(node));
    p0->data = num;
    while (p0->data > p1->data&&p1->next != NULL)
    {
        p2 = p1;
        p1 = p1->next;
    }
    if (p0->data <= p1->data)
    {
        if (head == p1) //头
        {
            p0->next = p1;
            head = p0;
        }
        else //中
        {
            p2->next = p0;
            p0->next = p1;
        }
    }
    else //尾
    {
        p1->next = p0;
        p0->next = NULL;
    }
    
    return (head);

}

 

3.实现单链表的删除

node *del(node **head, int num)
{
    node *p1 = NULL, *p2 = NULL;
    p1 = *head;
    while (num != p1->data&&p1->next != NULL)
    {
        p2 = p1;
        p1 = p1->next;
    }
    if (num == p1->data)
    {
        if (p1 == *head)
        {
            *head = p1->next;
            free(p1);
        }
        else
            p2->next = p1->next;
    }
    else printf("\n %d could not been found", num);
    return *head;

}

 

4.实现单链表排序

node *sort(node *head) //冒泡
{
    node *p;
    int n;int temp;
    n = length(head);
    if (head == NULL || head->next == NULL)return head;
    p = head;
    for (int j = 1;j < n;++j)
    {
        p = head;
        for (int i = 0;i < n - j;++i)
        {
            if (p->data > p->next->data)
            {
                temp = p->data;
                p->data = p->next->data;
                p->next->data = temp;
            }
            p = p->next;
        }
    }
    return head;
}

 

5.实现单链表的逆置

node *reverse(node *head)
{
    node *p1, *p2, *p3; //前驱指针 当前指针 缓存指针
    if (head == NULL || head->next == NULL) //没带头结点的空链表 和带头结点的空链表 判断是否为空
        return head;
    p1 = head, p2 = p1->next;
    while (p2)
    {
        p3 = p2->next;
        p2->next = p1;
        p1 = p2; //p1 p2后移
        p2 = p3;
    }
    head->next = NULL;
    head = p1;
    return head;
}