链表的使用

链表

c 复制代码
typedef struct {
	int val;
    struct ListNode *next;
}ListNode;

初始化

c 复制代码
ListNode* InitListNode(int val){
    ListNode *a ;
    a = (ListNode *)malloc(sizeof(ListNode));
    a->next = NULL;
    a->val = val;
    return a;
}

插入

c 复制代码
//在a后面插入b
void insert(ListNode *a , ListNode *b)
{
    b->next = a->next;
    a->next = b;
}

删除

c 复制代码
//删除a后面的节点
void del( ListNode * a){
    if(!a->next) return ;
    ListNode * p = a->next;
    ListNode * n = p->next;
    a->next = n;
    free(p);
}

访问节点

c 复制代码
ListNode *access(ListNode *n,int index){
    for (int i=0;i<index;i++){
        if(n->next==NULL) return NULL;
        n=n->next;
    }
    return n;
}

查找

c 复制代码
int find(ListNode * node,int target){
    int index = 0;
    while(node){
        if(node->val == target) return index;
        node = node->next;
        index++;
    }
    reutrn -1;
}

双向链表

c 复制代码
typedef struct DoublyListNode{
   int val;
   struct DoublyListNode *prev;
   struct DoublyListNode *next;
} DoublyListNode;

初始化

c 复制代码
ListNode *newDoublyListNode(int val){
    DoublyListNode *node;
    node = (DoublyListNode *)malloc(sizeof(DoublyListNode));
    node->prev = NULL;
    node->next = NULL;
    node->val = val;
}

析构函数

c 复制代码
void delDoublyListNode(DoublyListNode *node){
    free(node);
}

寻找第i个节点

c 复制代码
DoublyListNode GetElem(DoublyListNode * node, int i){
    for(int j=0;j<i;j++){
        if(node->next == NULL){
            printf("i too large!!\n");
            return NULL;
        }
        node = node->next;
    }
    return node;
}

插入

c 复制代码
//s插入到n的前面
void find(DoublyListNode *n ,DoublyListNode *s){
    s->next = n->next->prev;
    s->prev = n;
    n->next->prev = s;
    n->next = s;
}

删除

c 复制代码
void delete(DoublyListNode *s){
    
    s->prev->next = s->next;
    s->next->prev = s->prev;
    free(s);
}
相关推荐
风曦Kisaki24 分钟前
# 企业级网络架构Day03:网络层解析、路由原理、三层交换机、动态路由(OSPF)
网络·架构·智能路由器
wicb91wJ626 分钟前
Linux服务器性能调优常用命令
linux·服务器·网络
treesforest26 分钟前
Ipdatacloud IP 地址查询方案适合哪些场景?
大数据·网络·数据库·网络协议·tcp/ip·ip
TeDi TIVE27 分钟前
C#数据库操作系列---SqlSugar完结篇
网络·数据库·c#
北顾笙98028 分钟前
day29-数据结构力扣
数据结构
追兮兮28 分钟前
基于 GD32 与 LwIP 的 TCP OTA 固件升级实现
网络·网络协议·tcp/ip·tcp·gd32·ota
zhang1338308907529 分钟前
QY-18DL-1倾斜位移裂缝计:智能地质安全监测先锋
运维·网络·安全
你觉得脆皮鸡好吃吗30 分钟前
SQL注入 高权限注入(引入概念)
网络·数据库·sql·oracle·网络安全学习
RisunJan37 分钟前
Linux命令-nmap(网络探测和安全审计工具)
linux·网络·安全
Shadow(⊙o⊙)1 小时前
C++常见错误解析2.0
开发语言·数据结构·c++·后端·学习·算法