C语言双向链表快速入门教程

链表的声明

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点
} DoubleLinkedList;#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

创建双向链表

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode head; // 头节点DoubleLinkedListNode tail; // 尾节点
} DoubleLinkedList;#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *_newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = _newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = _newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;// 返回return list;
}

释放双向链表内存

核心代码:

void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *_newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = _newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = _newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}

判断链表是否为空

核心代码:

int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}

优化创建链表的代码,让头节点下一个节点指向尾节点,尾节点的上一个节点指向头节点。

DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存
extern int isEmptyDoubleLinkedList(DoubleLinkedList *list); // 判断是否为空链表#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}// 判断是否为空链表
int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}

获取链表的元素个数

给双向链表的结构加上size这个属性,每个新增的时候,这个数都+1,每次删除的时候都-1,这样这个属性的值代表的就是链表中元素的个数。

核心代码:

int sizeDoubleLinkedList(DoubleLinkedList *list) {return list->size;
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点int size; // 节点的个数
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存
extern int isEmptyDoubleLinkedList(DoubleLinkedList *list); // 判断是否为空链表
extern int sizeDoubleLinkedList(DoubleLinkedList *list); // 获取链表的元素个数#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;list->size = 0;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}// 判断是否为空链表
int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}// 获取链表的元素个数
int sizeDoubleLinkedList(DoubleLinkedList *list) {return list->size;
}

打印链表的内容

核心代码:

void printDoubleLinkedList(DoubleLinkedList *list) {if (list == NULL) {return;}if (list->head == NULL || list->head->next == NULL) {return;}DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {printf("%d ", current->data);current = current->next;}printf("\n");
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点int size; // 节点的个数
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存
extern int isEmptyDoubleLinkedList(DoubleLinkedList *list); // 判断是否为空链表
extern int sizeDoubleLinkedList(DoubleLinkedList *list); // 获取链表的元素个数
extern void printDoubleLinkedList(DoubleLinkedList *list); // 打印链表的内容#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;list->size = 0;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}// 判断是否为空链表
int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}// 获取链表的元素个数
int sizeDoubleLinkedList(DoubleLinkedList *list) {return list->size;
}// 打印链表的内容
void printDoubleLinkedList(DoubleLinkedList *list) {if (list == NULL) {return;}if (list->head == NULL || list->head->next == NULL) {return;}DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {printf("%d ", current->data);current = current->next;}printf("\n");
}

添加元素到链表末尾

核心代码:

void appendDoubleLinkedList(DoubleLinkedList *list, int value) {if (list == NULL || list->head == NULL || list->tail == NULL) {return;}// 构造新节点DoubleLinkedListNode *node = newDoubleLinkedListNode(value);// 插入到末尾DoubleLinkedListNode *oldPrev = list->tail->prev;oldPrev->next = node;node->prev = oldPrev;node->next = list->tail;list->tail->prev = node;// 元素个数增加list->size++;
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点int size; // 节点的个数
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存
extern int isEmptyDoubleLinkedList(DoubleLinkedList *list); // 判断是否为空链表
extern int sizeDoubleLinkedList(DoubleLinkedList *list); // 获取链表的元素个数
extern void printDoubleLinkedList(DoubleLinkedList *list); // 打印链表的内容
extern void appendDoubleLinkedList(DoubleLinkedList *list, int value); // 将元素添加到链表末尾#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;list->size = 0;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}// 判断是否为空链表
int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}// 获取链表的元素个数
int sizeDoubleLinkedList(DoubleLinkedList *list) {return list->size;
}// 打印链表的内容
void printDoubleLinkedList(DoubleLinkedList *list) {if (list == NULL) {return;}if (list->head == NULL || list->head->next == NULL) {return;}DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {printf("%d ", current->data);current = current->next;}printf("\n");
}// 将元素添加到链表末尾
void appendDoubleLinkedList(DoubleLinkedList *list, int value) {if (list == NULL || list->head == NULL || list->tail == NULL) {return;}// 构造新节点DoubleLinkedListNode *node = newDoubleLinkedListNode(value);// 插入到末尾DoubleLinkedListNode *oldPrev = list->tail->prev;oldPrev->next = node;node->prev = oldPrev;node->next = list->tail;list->tail->prev = node;// 元素个数增加list->size++;
}

main.c

#include "double_linked_list.h"int main(void) {// 创建链表DoubleLinkedList *list = newDoubleLinkedList();// 添加数据appendDoubleLinkedList(list, 11);printDoubleLinkedList(list);appendDoubleLinkedList(list, 22);printDoubleLinkedList(list);appendDoubleLinkedList(list, 33);printDoubleLinkedList(list);// 释放链表freeDoubleLinkedList(list);return 0;
}

输出:

11
11 22
11 22 33

移除元素

核心代码:

int removeDoubleLinkedList(DoubleLinkedList *list, int value) {int index = -1;if (list == NULL || list->head == NULL || list->tail == NULL || list->size <= 0) {return index;}// 查找对应的元素DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {index++;if (current->data == value) {break;}current = current->next;}// 如果找到了,则删除if (index >= 0 && index < list->size) {DoubleLinkedListNode *oldPrev = current->prev;DoubleLinkedListNode *oldNext = current->next;oldPrev->next = oldNext;oldNext->prev = oldPrev;free(current); // 记得释放节点的内存}// 元素个数减少list->size--;// 返回return index;
}

double_linked_list.h

#ifndef ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H
#define ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H// 公共头文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"// 双向链表的节点
typedef struct doubleLinkedListNode {int data;struct doubleLinkedListNode *next; // 下一个节点struct doubleLinkedListNode *prev; // 上一个节点
} DoubleLinkedListNode;// 双向链表
typedef struct doubleLinkedList {DoubleLinkedListNode *head; // 头节点DoubleLinkedListNode *tail; // 尾节点int size; // 节点的个数
} DoubleLinkedList;extern DoubleLinkedList *newDoubleLinkedList(); // 创建双向链表
extern void freeDoubleLinkedList(DoubleLinkedList *list); // 释放双向链表内存
extern int isEmptyDoubleLinkedList(DoubleLinkedList *list); // 判断是否为空链表
extern int sizeDoubleLinkedList(DoubleLinkedList *list); // 获取链表的元素个数
extern void printDoubleLinkedList(DoubleLinkedList *list); // 打印链表的内容
extern void appendDoubleLinkedList(DoubleLinkedList *list, int value); // 将元素添加到链表末尾
extern int removeDoubleLinkedList(DoubleLinkedList *list, int value); // 从链表中移除元素,成功返回其索引,失败返回-1#endif //ZDPC_ALGORITHM_DEV_DOUBLE_LINKED_LIST_H

double_linked_list.c

#include "double_linked_list.h"// 创建头节点
DoubleLinkedListNode *newDoubleLinkedListNode(int value) {// 申请节点的空间DoubleLinkedListNode *node = malloc(sizeof(DoubleLinkedListNode));// 初始化node->next = NULL;node->prev = NULL;node->data = value;// 返回return node;
}// 创建双向链表
DoubleLinkedList *newDoubleLinkedList() {// 申请链表的内存DoubleLinkedList *list = malloc(sizeof(DoubleLinkedList));// 头节点DoubleLinkedListNode *head = newDoubleLinkedListNode(0);// 尾结点DoubleLinkedListNode *tail = newDoubleLinkedListNode(0);// 初始化list->head = head;list->tail = tail;list->size = 0;// 关系list->head->next = list->tail;list->tail->prev = list->head;// 返回return list;
}// 释放双向链表内存
void freeDoubleLinkedList(DoubleLinkedList *list) {// 释放节点内存DoubleLinkedListNode *node = list->head->next;while (node->next != list->tail) {DoubleLinkedListNode *next = node->next;free(node);node = next;}// 释放首尾节点的内存free(list->head);free(list->tail);// 释放链表内存free(list);
}// 判断是否为空链表
int isEmptyDoubleLinkedList(DoubleLinkedList *list) {return list != NULL && list->head->next == list->tail;
}// 获取链表的元素个数
int sizeDoubleLinkedList(DoubleLinkedList *list) {return list->size;
}// 打印链表的内容
void printDoubleLinkedList(DoubleLinkedList *list) {if (list == NULL) {return;}if (list->head == NULL || list->head->next == NULL) {return;}DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {printf("%d ", current->data);current = current->next;}printf("\n");
}// 将元素添加到链表末尾
void appendDoubleLinkedList(DoubleLinkedList *list, int value) {if (list == NULL || list->head == NULL || list->tail == NULL) {return;}// 构造新节点DoubleLinkedListNode *node = newDoubleLinkedListNode(value);// 插入到末尾DoubleLinkedListNode *oldPrev = list->tail->prev;oldPrev->next = node;node->prev = oldPrev;node->next = list->tail;list->tail->prev = node;// 元素个数增加list->size++;
}// 从链表中移除元素
int removeDoubleLinkedList(DoubleLinkedList *list, int value) {int index = -1;if (list == NULL || list->head == NULL || list->tail == NULL || list->size <= 0) {return index;}// 查找对应的元素DoubleLinkedListNode *current = list->head->next;while (current != list->tail) {index++;if (current->data == value) {break;}current = current->next;}// 如果找到了,则删除if (index >= 0 && index < list->size) {DoubleLinkedListNode *oldPrev = current->prev;DoubleLinkedListNode *oldNext = current->next;oldPrev->next = oldNext;oldNext->prev = oldPrev;free(current); // 记得释放节点的内存}// 元素个数减少list->size--;// 返回return index;
}

main.c

#include "double_linked_list.h"int main(void) {// 创建链表DoubleLinkedList *list = newDoubleLinkedList();// 添加数据appendDoubleLinkedList(list, 11);appendDoubleLinkedList(list, 22);appendDoubleLinkedList(list, 33);printDoubleLinkedList(list);printf("元素个数:%d\n",list->size);// 删除数据removeDoubleLinkedList(list,22);printDoubleLinkedList(list);printf("元素个数:%d\n",list->size);// 释放链表freeDoubleLinkedList(list);return 0;
}

输出:

11 22 33
元素个数:3
11 33
元素个数:2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/7209.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MaxKB宝塔Docker安装并配置域名访问

准备 Linux系统 bt面板 默认环境LNMP随便装 服务器环境配置最好是4G&#xff0c; 占用硬盘存储大概1G 对于一些海外AI产品的对接需要使用香港或者海外的服务器 安装 在宝塔面板中打开SSH或者你本地使用SSH工具去链接服务器 运行docker命令 前提是放开服务器的8080端口 doc…

OPENAI中Assistants API的实现原理及示例代码python实现

OPENAI中Assistants API的实现原理及示例代码 前言 OPENAI是一家人工智能公司&#xff0c;致力于研究和开发人工智能技术。其中&#xff0c;Assistants API是OPENAI推出的一项人工智能服务&#xff0c;可以帮助开发者快速构建智能助手。本文将介绍Assistants API的实现原理&a…

spring Ai框架整合Ollama,调用本地大模型

Ollama使用 Ollama是一个用于在本地计算机上运行大模型的软件 软件运行后监听11434端口&#xff0c;自己写的程序要调大模型就用这个端口 ollama命令 ollama list&#xff1a;显示模型列表 ollama show&#xff1a;显示模型的信息 ollama pull&#xff1a;拉取模型 ollama pu…

【吊打面试官系列】Java高并发篇 - Java 线程池中 submit() 和 execute()方法有什么区别?

大家好&#xff0c;我是锋哥。今天分享关于 【Java 线程池中 submit() 和 execute()方法有什么区别&#xff1f;】面试题&#xff0c;希望对大家有帮助&#xff1b; Java 线程池中 submit() 和 execute()方法有什么区别&#xff1f; 两个方法都可以向线程池提交任务&#xff0c…

Redis - Zset 有序集合

前言 它保留了集合不能有重复成员的特点&#xff0c;但与集合不同的是&#xff0c;有序集合中的每个元素都有⼀个唯⼀的浮点类型的分数&#xff08;score&#xff09;与之关联&#xff0c;有序集合中的元素是可以维护有序性的&#xff0c;但这个有序不是⽤下标作为排序依据⽽是…

STM32F4xx开发学习—GPIO

GPIO 学习使用STM32F407VET6GPIO外设 寄存器和标准外设库 1. 寄存器 存储器映射 存储器本身是不具有地址的&#xff0c;是一块具有特定功能的内存单元&#xff0c;它的地址是由芯片厂商或用户分配&#xff0c;给存储器分配地址的过程就叫做存储区映射。给内存单元分配地址之后…

Pytorch实现图片异常检测

图片异常检测 异常检测指的是在正常的图片中找到异常的数据&#xff0c;由于无法通过规则进行识别判断&#xff0c;这样的应用场景通常都是需要人工进行识别&#xff0c;比如残次品的识别&#xff0c;图片异常识别模型的目标是可以代替或者辅助人工进行识别异常图片。 AnoGAN…

leetcode 413.等差数列划分

思路&#xff1a;dp 因为正在练dp&#xff0c;所以这里就用dp的方法做了。 通过我们做过的一个题&#xff0c;就是leetcode 53.最大子段和那个&#xff0c;还有最长递增序列那一类题&#xff0c;我们可以知道&#xff0c;设置dp含义一般都是以什么什么数结尾&#xff0c;然后…

python实现的冒泡、快速排序

目录 概要 冒泡排序 快速排序 概要 插入排序&#xff0c;是基于比较和移动操作实现的排序&#xff0c;从算法效率上看不够高&#xff0c;但是实现简单&#xff0c;适用于数据量比较少的场景。 现在讲一讲基于比较和交换操作实现的排序。 冒泡排序 首先是冒泡排序。冒泡排序效率…

C++里的new

C里的new&#xff1a; new开辟的空间在堆上&#xff0c;而一般声明的变量存放在栈上。当在局部函数中new出一段新的空间&#xff0c;该段空间在局部函数调用结束后仍然能够使用&#xff0c;可以用来向主函数传递参数。new出来的是一段空间的首地址。所以一般需要用指针来存放这…

油烟净化器买家必看!商用油烟净化器功效及使用方法盘点

我最近分析了餐饮市场的油烟净化器等产品报告&#xff0c;解决了餐饮业厨房油腻的难题&#xff0c;更加方便了在餐饮业和商业场所有需求的小伙伴们。 在选择商用油烟净化器时&#xff0c;了解其功效和正确的使用方法至关重要。让我们一起来盘点一下。 高效净化油烟 商用油烟…

存储故障后oracle报—ORA-01122/ORA-01207故障处理---惜分飞

客户存储异常,通过硬件恢复解决存储故障之后,oracle数据库无法正常启动(存储cache丢失),尝试recover数据库报ORA-00283 ORA-01122 ORA-01110 ORA-01207错误 以前处理过比较类似的存储故障case:又一起存储故障导致ORA-00333 ORA-00312恢复存储故障,强制拉库报ORA-600 kcbzib_kcr…

零基础入门篇①② Python标准数据类型--数字

Python从入门到精通系列专栏面向零基础以及需要进阶的读者倾心打造,9.9元订阅即可享受付费专栏权益,一个专栏带你吃透Python,专栏分为零基础入门篇、模块篇、网络爬虫篇、Web开发篇、办公自动化篇、数据分析篇…学习不断,持续更新,火热订阅中🔥专栏订阅地址 👉Python从…

代码随想录算法训练营第30天 | 回溯算法总结、332.重新安排行程、51. N皇后、37. 解数独

代码随想录算法训练营第30天 | 回溯算法总结 回溯算法模板组合问题切割问题子集问题排列问题去重问题 回溯算法模板 void backtracking(参数) {if (终止条件) {存放结果;return;}for (选择&#xff1a;本层集合中元素&#xff08;树中节点孩子的数量就是集合的大小&#xff09…

接口测试及常用的接口测试工具(Postman/Jmeter)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 首先&#xff0c;什么是接口呢&#xff1f; 接口一般来说有两种&#xff0c;一种是程序内部的接…

[Flutter]创建一个私有包并使用

在Flutter中创建一个自己的私有组件&#xff08;通常称为包或库&#xff09;&#xff0c;并通过Dart的包管理工具pub进行使用。 一、创建一个新的Flutter包 1.使用命令行创建 使用Flutter命令行工具来创建一个新的包&#xff1a; $ flutter create --templatepackage my_pri…

软件公司为什么很少接二开项目?

前言 很多企业由于原有项目还在继续运营&#xff0c;但原有技术公司不想再合作或者不想再维持整个技术团队等原因&#xff0c;就需要找一个新的软件公司继续维护原有软件系统。但是一接触往往发现很多软件公司拒绝接手第三方的软件项目&#xff0c;这究竟是什么原因呢&#xff…

皮尔逊相关系数介绍及实现(python,java)

什么是皮尔逊相关系数&#xff1f; 皮尔逊相关系数&#xff08;Pearson correlation coefficient&#xff09;&#xff1a;由卡尔皮尔逊&#xff08;Karl Pearson&#xff09;提出&#xff0c;是衡量两个变量线性相关程度的统计指标&#xff0c;它的值介于-1与1之间&#xff0…

某东抢购某台脚本-低调

某东抢购某台脚本 小白操作-学习使用 注意&#xff1a; 本文部分变量已做脱敏处理&#xff0c;仅用于测试和学习研究&#xff0c;禁止用于商业用途&#xff0c;不能保证其合法性&#xff0c;准确性&#xff0c;完整性和有效性&#xff0c;请根据情况自行判断。技术层面需要提…

329. 矩阵中的最长递增路径

329. 矩阵中的最长递增路径 思路 从每个点下去dfs。然后对于每个点都进行dfs&#xff0c;并且memo记录的是当前点到终点的最大步数。 class Solution { public:static constexpr int dirs[4][2] {{0,1},{0,-1},{1, 0},{-1,0}}; int longestIncreasingPath(vector<vecto…