C语言 链表基本函数

#include <stdio.h>
#include <malloc.h>
typedef struct my_node mynode;
struct my_node{
    struct my_node *next;
    int             data;
};

void push_node(mynode **head,int data)
{
    mynode *temp = *head;
    if(*head == NULL)
    {
        *head = (mynode *)malloc(sizeof(mynode));
        (*head) ->data = data;
        (*head) ->next = NULL;
    }
    else
    {
        while(temp ->next != NULL)
            temp = temp ->next;
        temp ->next  = (mynode *)malloc(sizeof(mynode));
        temp ->next ->data = data;
        temp ->next ->next = NULL;
    }

}
void pop_node(mynode **head)
{
    mynode *temp = *head, *prev;
    while(temp ->next != NULL)
    {
        prev = temp;
        temp = temp ->next;
    }

    free(prev ->next);
    prev ->next = NULL;
}

void del_node(mynode **head,int index)
{
    mynode *temp = *head, *tmp;
    while(index -- != 1)
        temp = temp ->next;
    tmp = temp ->next;
    temp ->next = temp ->next->next;
    free(tmp);
}

void ins_node(mynode **head,int index,int data)
{
    mynode *temp = *head, *tmp;
    while(index -- != 1)
        temp = temp ->next;
    tmp = temp ->next;

    temp ->next = NULL;
    temp ->next = (mynode *)malloc(sizeof(mynode));
    temp ->next ->next = tmp;
    temp ->next ->data = data;

}

int find_data(mynode *head,int data)
{
    mynode *temp = head;
    int i =0;
    while(temp ->next != NULL)
    {
        if(data == temp ->data)
            return i;
        temp = temp ->next;
        i++;
    }
    return 0;

}
void back_ward(mynode **head)
{
    mynode *now = *head, *temp, *prev;

    while(now ->next != NULL)
    {
        temp = now->next;

        if(now == *head)
            now->next = NULL;
        else
            now ->next  = prev;

        prev = now;
        now = temp;
    }

    now ->next = prev;
    *head = now;
}
void sort_node(mynode **head)
{
    mynode *curNode = (*head) ->next,*prevNode,*nextNode,*tempNode;

    (*head) ->next =NULL;//有序节点尾为null
    while(curNode != NULL)
    {
        tempNode = curNode->next;
        if(curNode ->data > (*head) ->data)//大于头结点,新头结点
        {
            curNode->next = *head;
            (*head) = curNode;

        }
        else
        {
            prevNode = *head;
            nextNode = (*head) ->next;
            while(nextNode != NULL && curNode ->data <  nextNode->data) //定位需要插入的位置
            {
                prevNode = nextNode;
                nextNode = nextNode ->next;
            }
            curNode ->next = prevNode ->next;
            prevNode ->next =curNode;
        }
        curNode = tempNode;
    }

}

int main()
{
    mynode *head = NULL;
//     head = (mynode *)malloc(sizeof(mynode));
//     head ->data =10;
//     head ->next = NULL;

    push_node(&head,10);
    push_node(&head,100);
    push_node(&head,101);
    push_node(&head,102);
    push_node(&head,103);
    pop_node(&head);
    push_node(&head,103);


    del_node(&head,2);
    ins_node(&head,2,101);
    find_data(head,102);

    back_ward(&head);

    back_ward(&head);

    sort_node(&head);

    return 0;

}

收藏于 2013-03-25
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值