数据结构---单向链表

单向链表

cs 复制代码
//链表的创建
Link_t *create_link()
{
    Link_t *plink = malloc(sizeof(Link_t));
    if(NULL == plink)
    {
        perror("fail plink");
        return NULL;
    }
    plink->phead = NULL;
    plink->clen = 0;
    return plink;
}
cs 复制代码
//头插
int push_link_head(Link_t *plink, DataType data)
{
    Link_Node_t *pnode = malloc(sizeof(Link_Node_t));
    if(NULL == pnode)
    {
        perror("fail malloc");
        return -1;
    }
    pnode->data = data;
    pnode->pnext = NULL;

    pnode->pnext = plink->phead;
    plink->phead = pnode;
    plink->clen++;

    return 0;
}
cs 复制代码
//尾插
int push_link_end(Link_t *plink, DataType data)
{
    Link_Node_t *p = plink->phead;
    if(p == NULL)
    {
        push_link_head(plink, data);
    }
    else
    {
        while(p->pnext != NULL)
        {
            p = p->pnext;
        }
        Link_Node_t *pnode = malloc(sizeof(Link_Node_t));
        if(NULL == pnode)
        {
            perror("fail pnode");
            return -1;
        }
        p->pnext = pnode;
        pnode->pnext = NULL;
        pnode->data = data;
        plink->clen++;
    }
    return 0;
}
cs 复制代码
//头删
int push_head_pop(Link_t *plink)
{
    Link_Node_t *p = plink->phead;
    if(p == NULL)
    {
        return 0;
    }
    else
    {
        plink->phead = p->pnext;
        free(p);
    }
    plink->clen--;
    return 1;
}
cs 复制代码
//尾删
int push_end_pop(Link_t *plink)
{
    Link_Node_t *p = plink->phead;
    if(p == NULL)
    {
        return 0;
    }
    else if(p->pnext == NULL)
    {
        push_head_pop(plink);
    }
    else
    {
        while(p->pnext->pnext != NULL)
        {
            p = p->pnext;
        }
        free(p->pnext);
        p->pnext = NULL;
    plink->clen--;
    }
    return 1;
}

在进行排序时,一次遍历结束指针指到了结尾,要重新把指针归到头节点,否则排序不成功。

cs 复制代码
//排序
void push_sort(Link_t *plink)
{
    if(1 == plink->clen || plink->phead == NULL)
    {
        return;
    }
    Link_Node_t *pinsert = NULL;
    Link_Node_t *ptmp = plink->phead->pnext;
    plink->phead->pnext = NULL;
    while(ptmp != NULL)
    {
    Link_Node_t *p = plink->phead;
        pinsert = ptmp;
        ptmp = ptmp->pnext;
        if(p->data > pinsert->data)
        {
            pinsert->pnext = plink->phead;
            plink->phead = pinsert;
        }
        else
        {
            while(p->pnext != NULL && p->pnext->data < pinsert->data)
            {
                p = p->pnext;
            }
            pinsert->pnext = p->pnext;
            p->pnext = pinsert;
        }
    }
}
相关推荐
努力也学不会java8 分钟前
【设计模式】抽象工厂模式
java·设计模式·oracle·抽象工厂模式
用户60830892904718 分钟前
集合处理利器,Java中的Stream流API
java·后端
玉衡子19 分钟前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
9号达人22 分钟前
Java 14 新特性详解与实践
java·后端·面试
ytadpole24 分钟前
揭秘XXL-JOB:Bean、GLUE 与脚本模式的底层奥秘
java·后端
今后12338 分钟前
【数据结构】二叉树的概念
数据结构·二叉树
计算机毕业设计木哥39 分钟前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计
青衫客3639 分钟前
Spring异步编程- 浅谈 Reactor 核心操作符
java·spring·响应式编程
Seven9740 分钟前
剑指offer-30、连续⼦数组的最⼤和
java
BenChuat43 分钟前
Java常见排序算法实现
java·算法·排序算法