数据结构——单链表查询、逆序、排序

1、思维导图

2、查、改、删算法

复制代码
//快慢排序法找中间值
int mid_link(Link_t *plink)
{
    Link_Node_t *pfast = plink->phead;
    Link_Node_t *pslow = pfast;
    int m = 0;
    while(pfast != NULL)
    {
        pfast = pfast->pnext;
        ++m;
        if(m % 2 == 0)
        {
            pslow = pslow->pnext;
        }
    }
    printf("%d\n",pslow->data);
    printf("%p\n",pslow);
        
}


//快慢排序法查询倒数第k个
Link_Node_t *recipe_link_count(Link_t *plink)
{
    Link_Node_t *pfast = plink->phead;
    Link_Node_t *pslow = pfast;
    int m = 0;
    int n;
    scanf("%d",&n);
    while(pfast != NULL && m < n)
    {
        pfast = pfast->pnext;
        m++;
    }
    while(pfast != NULL)
    {
        pfast = pfast->pnext;
        pslow = pslow->pnext;
    }
    //printf("%d\n",pslow->data);
    //printf("%p\n",pslow);
    return pslow;
}


//删除指定节点
int pop_point_node(Link_t *plink)
{
    int n;
    int m = 0;
    printf("选择删除节点:");
    scanf("%d",&n);
    Link_Node_t *p = plink->phead;
    Link_Node_t *pdel = NULL;
    Link_Node_t *ptmp = NULL;
    if(p == NULL)
    {
        return 0;
    }
    else if(p->data == n)
    {
        pdel = p;
        plink->phead = p->pnext;
    }
    else if(p != NULL)
    {
        while(p->data != n)
        {
            ptmp = p;
            p = p->pnext;
        }
        pdel = p;
        ptmp->pnext = pdel->pnext;
    }
            free(pdel);
    return 0;
}

3、单链表逆序

复制代码
//链表逆序
int reverse_link(Link_t *plink)
{
    if(is_empty_link(plink))
        return 0;
    Link_Node_t *ptmp = plink->phead;
    Link_Node_t *pinsert = NULL;
    plink->phead = NULL;
    while(ptmp != NULL)
    {
        pinsert = ptmp;
        ptmp = ptmp->pnext;
        pinsert->pnext = plink->phead;
        plink->phead = pinsert;
    }
}

4、插入排序(从未排序部分取出一个元素,插入到已排序部分的正确位置)

复制代码
void insert_sort_link(Link_t *plink)
{
    if(is_empty_link(plink) || 1 == plink->clen)
    {
        return;
    }
    Link_Node_t *ptmp = plink->phead->pnext;
    Link_Node_t *pinsert = NULL;
    Link_Node_t *p = NULL;
    plink->phead->pnext = NULL;
    while(ptmp != NULL)
    {
    pinsert = ptmp;
    ptmp = ptmp->pnext;
    if(pinsert->data <= plink->phead->data)
    {
        pinsert->pnext = plink->phead; //头插
        plink->phead = pinsert;
    }
    else
    {
        p = plink->phead;
       while(p->pnext != NULL && p->pnext->data < pinsert->data)
       {
           p = p->pnext;
       }
        pinsert->pnext = p->pnext;  //尾插
        p->pnext = pinsert;   
    }
    }
}

双向链表------插删查改:

复制代码
#include<stdio.h>
#include"dlink.h"
#include<stdlib.h>

DLink_t *create_doulink()
{
    DLink_t *pdoulink = malloc(sizeof(DLink_t));
    if(NULL == pdoulink)
    {
        perror("fail creat");
        return NULL;
    }
    pdoulink->phead = NULL;
    pdoulink->clen = 0;
    pthread_mutex_init(&pdoulink->mutex,NULL);
    return pdoulink;
}

//判空
int is_empty_doulink(DLink_t *pdoulink)
{
    return NULL == pdoulink->phead;
}

//头插
int push_doulink_head(DLink_t *pdoulink,DataType data)
{
    DLink_Node_t *pnode = malloc(sizeof(DLink_Node_t));
    if(NULL == pnode)
    {
        perror("fail malloc");
        return -1;
    }
    pnode->ppre = NULL;
    pnode->pnext = NULL;
    pnode->data = data;
    
    if(is_empty_doulink(pdoulink))
    {
        pdoulink->phead = pnode;
    }
    else
    {
        pnode->pnext = pdoulink->phead;
        pdoulink->phead->ppre = pnode;
        pdoulink->phead = pnode;
    }
    pdoulink->clen++;
}

//遍历
void print_pdoulink(DLink_t *pdoulink,int flag)
{
    if(is_empty_doulink(pdoulink))
        return;
    DLink_Node_t *p = pdoulink->phead;
    if(flag)
    {
        while(p != NULL)
        {
            printf(" %d %s %d\n",p->data.id,p->data.name,p->data.score);
            p = p->pnext;
        }
    }
    else
    {
        while(p->pnext != NULL)
        {
            p = p->pnext;
        }
        while(p != NULL)
        {
            printf(" %d %s %d\n",p->data.id,p->data.name,p->data.score);
            p = p->ppre;
        }
    }
    
}

//尾插
int push_doulink_tail(DLink_t *pdoulink ,DataType data)
{
    DLink_Node_t *pnode = malloc(sizeof(DLink_Node_t));
    if(pnode == NULL)
    {
        perror("fail malloc");
        return -1;
    }
    pnode->data = data;
    pnode->ppre = NULL;
    pnode->pnext = NULL;
    if((is_empty_doulink(pdoulink)))
    {
        push_doulink_head(pdoulink,data);
        free(pnode);
    }
    else
    {
        DLink_Node_t *p = pdoulink->phead;
        while(p->pnext != NULL)
        {
            p = p->pnext;
        }
        p->pnext = pnode;
        pnode->ppre = p;
    }

}

//头删
int pop_head(DLink_t *pdoulink)
{
    if(is_empty_doulink(pdoulink))
    {
        return 0;
    }
    DLink_Node_t *p = pdoulink->phead;
    pdoulink->phead = p->pnext;
    if(p->pnext != NULL)
    {
        p->pnext->ppre = NULL;
    }
    free(p);
}

//尾删
int pop_tail(DLink_t *pdoulink)
{
    DLink_Node_t *p = pdoulink->phead;
    if(is_empty_doulink(pdoulink))
    {
        return 0;
    }
    else if(p->pnext == NULL)
    {
        pop_head(pdoulink);
    }
    else
    {
        while(p->pnext->pnext != NULL)
        {
            p = p->pnext;
        }
        free(p->pnext);
        p->pnext = NULL;
    }
}

//查找 name
DataType *find_dliink_data(DLink_t *pdoulink,char *data)
{
    if(is_empty_doulink(pdoulink))
        return NULL;
    DLink_Node_t *p = pdoulink->phead;
    while(p != NULL)
    {
        if(strcmp(p->data.name,data) == 0)
        {
            return &(p->data);
        }
        p = p->pnext;
    }
    return NULL;
}

//修改(根据name查找)
void update_dlink_data(DLink_t *pdoulink,char *old_data,char *new_data)
{
    if(is_empty_doulink(pdoulink))
        return;
    DLink_Node_t *p = pdoulink->phead;
    while(p != NULL)
    {
        if(strcmp(p->data.name,old_data) == 0)
        {
            strcpy(p->data.name,new_data);
            break;
        }
        p = p->pnext;
    }
    
}

//销毁

void destory_dlink(DLink_t *pdoulink)
{
        while(!(is_empty_doulink(pdoulink)))
        {
            pop_head(pdoulink);
        }
        free(pdoulink);
}
相关推荐
木斯佳3 小时前
HarmonyOS 6实战:从爆款vlog探究鸿蒙智能体提取关键帧算法
算法·华为·harmonyos
Mr.朱鹏3 小时前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
WJSKad12354 小时前
【DepthPro】实战教程:单目深度估计算法详解与应用
算法
wzqllwy4 小时前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
We་ct4 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝
重生之我是Java开发战士4 小时前
【递归、搜索与回溯】二叉树中的深度优先搜索:布尔二叉树,求根节点到叶节点数字之和,二叉树剪枝,验证二叉搜索树,第K小的元素,二叉树的所有路径
算法·深度优先·剪枝
篮l球场4 小时前
矩阵置零
算法
lihihi4 小时前
P1650 [ICPC 2004 Shanghai R] 田忌赛马(同洛谷2587)
开发语言·算法·r语言
朱一头zcy4 小时前
[牛客]BC38 变种水仙花
算法
努力学算法的蒟蒻4 小时前
day105(3.6)——leetcode面试经典150
算法·leetcode·面试