IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 单向链表系统函数 -> 正文阅读

[数据结构与算法]单向链表系统函数

链式表:
单向链表 节点:数据元素+指针域(下一个Node的内存)

main.c

#include <stdio.h>
#include <stdlib.h>
#include "singlelinketlist.h"

void print(int num){
	printf("%d ",num);
}
void showMenu(void){
	printf("***单向链表功能测试*****\n");
	printf("** 1.插入一个元素 \n");
	printf("** 2.查找  \n");
	printf("** 3.链表为空判断 \n");
	printf("** 4.元素个数 \n");
	printf("** 5.遍历   \n");
	printf("** 6.清空所有元素  \n");
	printf("** 7.在表头插入 \n");
	printf("** 8.在末尾插入 \n");
	printf("** 9.删除 \n");
	printf("** 10.删除第一个元素 \n");
	printf("** 11.删除最后一个元素 \n");
	printf("** 12.获取指定位置的元素 \n");
	printf("** 13.第一个元素 \n");
	printf("** 14.最后一个元素 \n");
	printf("** 15.逆序  \n");
	printf("** 16.快速插入数据\n");
	printf("** 17.1,n,2,n-1,3,n-2,4,...\n");
	printf("** 18.按指定元素个数逆序 \n"); 
	printf("** 0.销毁 \n");
	printf(">>>>>");
}
void find(SLinketList list){
	printf("请输入要查找的值:");
	ETYPE key = 0;
	scanf("%d",&key);
	int ret = slinket_list_find(list,&key);
	if(ret == -1){
		printf("没有该元素!\n");
	}else{
		printf("该元素第一次出现在:%u\n",ret);
	}
}
void insert_data(SLinketList list){
	printf("请输入插入元素的个数:");
	size_t num = 0;
	scanf("%u",&num);
	size_t i;
	for(i=0;i<num;i++){
		slinket_list_insert_back(list,i+1);
	}
	slinket_list_travel(list,print);
	printf("\n");
}
void reverse(SLinketList list){
	size_t cnt = 0;
	printf("请输入按几个元素逆序:");
	scanf("%u",&cnt);
	slinket_list_reverse_by_count(list,cnt);
	slinket_list_travel(list,print);
	printf("\n");	
}

void add(SLinketList list){
	printf("请输入位置[0-%u]:",slinket_list_size(list));
	size_t pos = 0;
	scanf("%u",&pos);
	printf("请输入要插入的元素:");
	ETYPE elem;
	scanf("%d",&elem);
	int ret = slinket_list_insert(list,pos,elem);
	if(ret == 0){
		printf("插入成功!\n");
	}else{
		printf("插入失败!\n");
	}
}

void test_single_linket_list(void){
	SLinketList list = slinket_list_create();
	ETYPE data = 0;
	size_t pos = 0;
	int ret = 0;
	while(true){
		showMenu();
		int opt = 0;
		scanf("%d",&opt);
		switch(opt){
			case 1:
				add(list);
				break;
			case 2:
				find(list);
				break;
			case 3:
				slinket_list_is_empty(list)?printf("空空如也!\n"):printf("海纳百川\n");
				break;
			case 4:
				printf("元素个数:%u\n",slinket_list_size(list));
				break;
			case 5:
				slinket_list_travel(list,print);
				printf("\n");
				break;
			case 6:
				slinket_list_clear(list);
				break;
			case 7:
				printf("请输入要插入元素:");
				scanf("%d",&data);
				ret = slinket_list_insert_front(list,data);
				if(ret == 0){
					printf("插入成功!\n");
				}else{
					printf("插入失败!\n");
				}
				break;
			case 8:
				printf("请输入要插入的元素:");
				scanf("%d",&data);
				ret = slinket_list_insert_back(list,data);
				if(ret == 0){
					printf("插入成功!\n");
				}else{
					printf("插入失败!\n");
				}
				break;
			case 9:
				printf("请输入要删除的位置:");
				scanf("%u",&pos);
				ret = slinket_list_delete(list,pos,&data);
				if(ret == 0){
					printf("删除的结点元素为:%d\n",data);
				}else{
					printf("删除失败!\n");
				}
				break;
			case 10:
				ret = slinket_list_delete_front(list,&data);
				if(ret == 0){
					printf("删除的结点元素为:%d\n",data);
				}else{
					printf("删除失败!\n");
				}
				break;
			case 11:
				ret = slinket_list_delete_back(list,&data);
				if(ret == 0){
					printf("删除的结点元素为:%d\n",data);
				}else{
					printf("删除失败!\n");
				}
				break;
			case 12:
				printf("请输入要获得结点的位置[0-%u)",slinket_list_size(list));
				scanf("%u",&pos);
				ret = slinket_list_get(list,pos,&data);
				if(ret == 0){
					printf("%u位置结点的元素为%d\n",pos,data);
				}else{
					printf("获取出错!\n");
				}
				break;
			case 13:
				ret = slinket_list_get_front(list,&data);
				if(ret == 0){
					printf("第一个位置结点的元素为%d\n",data);
				}else{
					printf("获取出错!\n");
				}
				break;
			case 14:
				ret = slinket_list_get_back(list,&data);
				if(ret == 0){
					printf("最后一个位置结点的元素为%d\n",data);
				}else{
					printf("获取出错!\n");
				}
				break;
			case 15:
				slinket_list_reverse(list);
				slinket_list_travel(list,print);
				printf("\n");
				break;
			case 16:
				insert_data(list);
				break;
			case 17:
				slinket_list_reset_seq(list);
				slinket_list_travel(list,print);
				printf("\n");
				break;
			case 18:
				reverse(list); 
				break;
			case 0:
				slinket_list_destroy(list);
				return;
		}
	}
}


int main(int argc, char *argv[]) {
	test_single_linket_list();
	return 0;
}

slinketlist.h

#ifndef SINGLE_LINKET_LIST_H__
#define SINGLE_LINKET_LIST_H__
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

//单向链表结点

typedef int ETYPE;

//单向链表结点类型 
typedef struct Node{
	ETYPE elem;     //元素
	struct Node *next; //下一个节点的位置	
}SNode,*SLinketList; 
//typedef struct Node  SNode; 
//typedef struct Node * SLinketList;
//SLinketList list; 
#define NODESIZE sizeof(struct Node)

//SLinketList 是一个类型名,不是变量名   struct Node*   单向链表的类型

//SLinketList list=NULL;   struct Node* list; 
//typedef struct Node * SLinketList;  // SLinketList list = slinket_list_create(); 
//单向链表 有一个头结点  并且头结点不保存数据 只是作为一个标识作用  
//头结点不保存数据的原因是为了插入和删除时 不需要传二级指针
//创建一个单向链表  只malloc一个头结点即可 
SLinketList slinket_list_create(void); 
//判断单向链表是否为空 
bool slinket_list_is_empty(SLinketList head);
//单向链表中元素的个数
size_t slinket_list_size(SLinketList head);
//在指定位置pos插入一个元素elem  第一个位置默认为0 
int slinket_list_insert(SLinketList head,size_t pos,ETYPE elem);
//在单向链表前面插入一个元素elem
int slinket_list_insert_front(SLinketList head,ETYPE elem);
//在单向链表末尾插入一个元素elem
int slinket_list_insert_back(SLinketList head,ETYPE elem);
//删除指定位置pos的元素
int slinket_list_delete(SLinketList head,size_t pos,ETYPE *pelem);
//删除单向链表第一个元素
int slinket_list_delete_front(SLinketList head,ETYPE *pelem);
//删除末尾的元素
int slinket_list_delete_back(SLinketList head,ETYPE *pelem);
//获取指定位置pos的元素 
int slinket_list_get(SLinketList head,size_t pos,ETYPE *pelem);
//获取第一个元素
int slinket_list_get_front(SLinketList head,ETYPE *pelem);
//获取最后一个元素
int slinket_list_get_back(SLinketList head,ETYPE *pelem);
//根据值key来查找   返回-1表示没有该值  否则返回位置 
int slinket_list_find(SLinketList head,ETYPE *pelem);
//遍历单向链表
void slinket_list_travel(SLinketList head,void (*travel)(int)); 
//删除所有元素  清空所有元素 
void slinket_list_clear(SLinketList head);
//销毁单向链表
void slinket_list_destroy(SLinketList head); 
//单向链表逆序
void slinket_list_reverse(SLinketList head);
//获取倒数第n个元素
int slinket_list_get_last(SLinketList head,size_t pos,ETYPE *pelem);//[1,... 
// a1,a2,a3... an-1,an    a1,an,a2,an-1,a3,an-2,...
void slinket_list_reset_seq(SLinketList head);
// 按指定元素个数逆序  a1,a2,a3,a4,a5,a6,a7,a8   a3,a2,a1,a6,a5,a4,a8,a7
void slinket_list_reverse_by_count(SLinketList head,size_t count); 
#endif //SINGLE_LINKET_LIST_H__

slinketlist.c

#include "singlelinketlist.h"

//单向链表结点
/*
typedef int ETYPE;

typedef struct Node{
	ETYPE elem;     //元素
	struct Node *next; //下一个节点的位置	
}SNode,*SLinketList; 
*/
//typedef struct Node * SLinketList;  // SLinketList list = slinket_list_create(); 
//单向链表 有一个头结点  并且头结点不保存数据 只是作为一个标识作用  
//头结点不保存数据的原因是为了插入和删除时 不需要传二级指针
//创建一个单向链表  只malloc一个头结点即可 
//SLinketList list = slinket_list_create();
//SLinketList list;
//init(&list);
//创建一个单向链表  单向链表没有元素  为空   带头结点的 头结点不保存数据 
SLinketList slinket_list_create(void){
	struct Node* head = (struct Node*)malloc(NODESIZE);//头结点  
	if(head==NULL){
		return NULL;
	}
	head->next = NULL;
	return head;
}
//判断单向链表是否为空 
bool slinket_list_is_empty(SLinketList head){//head 指针 指向头结点    *head头结点 
	return head->next == NULL; //(*head).next == NULL     
}
//单向链表中元素的个数
size_t slinket_list_size(SLinketList head){
	size_t size = 0;
	struct Node *node = head->next;//head指向头结点   head->next指向第一个结点 
	while(node != NULL){
		size++;
		node = node->next;//让node指针指向下一个节点 
	} 
	return size; 
}
//获取pos位置的前一个结点  如果pos过大,返回NULL 
static struct Node * slinket_list_get_prev_node(SLinketList head,size_t pos){
	struct Node *node = head; 
	size_t i;
	for(i=0;node!=NULL&&i<pos;i++){
		node = node->next;
	}
	return node;
} 
//在指定位置pos插入一个元素elem  第一个位置默认为0 
int slinket_list_insert(SLinketList head,size_t pos,ETYPE elem){	//要获取pos-1节点的指针  pos==0 头结点
	struct Node *prev = slinket_list_get_prev_node(head,pos);
	if(prev == NULL){
		return -1;
	}
	struct Node *node = (struct Node *)malloc(NODESIZE);
	if(node==NULL){
		return -2;
	}
	node->elem = elem;
	node->next = prev->next;
	prev->next = node;
	return 0;
}
//在单向链表前面插入一个元素elem
int slinket_list_insert_front(SLinketList head,ETYPE elem){
	struct Node *node = (struct Node *)malloc(NODESIZE);
	if(node==NULL){
		return -1;
	}
	node->elem = elem;
	node->next = head->next;
	head->next = node;
	return 0;
}
//在单向链表末尾插入一个元素elem
int slinket_list_insert_back(SLinketList head,ETYPE elem){
	//size_t size = slinket_list_size(head);
	//return slinket_list_insert(head,sie,elem);
	struct Node *last = head;
	while(last->next!=NULL){
		last = last->next;
	}
	//last->next == NULL
	//last->next = (struct Node *)malloc(NODESIZE);
	//last->next->elem = elem;  last->next->next = NULL;
	struct Node *node = (struct Node *)malloc(NODESIZE);
	node->elem = elem;
	node->next = NULL;
	last->next = node;
	return 0;
}
//删除指定位置pos的元素
int slinket_list_delete(SLinketList head,size_t pos,ETYPE *pelem){
	struct Node *prev = slinket_list_get_prev_node(head,pos);
	if(prev == NULL || prev->next == NULL){
		return -1;
	}
	struct Node *curr = prev->next;
	prev->next = curr->next;
	*pelem = curr->elem;
	free(curr);
	return 0;
}
//删除单向链表第一个元素
int slinket_list_delete_front(SLinketList head,ETYPE *pelem){
	if(head->next == NULL){
		return -1;
	}
	*pelem = head->next->elem;
	struct Node *first = head->next;
	head->next = first->next;
	free(first);
	return 0;
}
//删除末尾的元素
int slinket_list_delete_back(SLinketList head,ETYPE *pelem){
	if(head->next == NULL){
		return -1;
	} 
	//size_t size = slinket_list_size(head);
	//return slinket_lsit_delete(head,size-1,pelem);
	struct Node *lastSec = head;
	while(lastSec->next->next != NULL){
		lastSec = lastSec->next;
	}
	//lastSec记录的是倒数第二个结点
	*pelem = lastSec->next->elem; 
	free(lastSec->next);//释放最后一个结点的内存 
	lastSec->next = NULL; 
	return 0; 
}
//获取指定位置pos的元素 
int slinket_list_get(SLinketList head,size_t pos,ETYPE *pelem){
	struct Node *node = slinket_list_get_prev_node(head,pos+1);
	if(node == NULL){
		return -1;
	}
	*pelem = node->elem;
	return 0;
}
//获取第一个元素
int slinket_list_get_front(SLinketList head,ETYPE *pelem){
	if(head->next == NULL){
		return -1;
	}
	*pelem = head->next->elem;
	return 0;
}
//获取最后一个元素
int slinket_list_get_back(SLinketList head,ETYPE *pelem){
	if(head->next == NULL){
		return -1;
	}
	struct Node *last = head->next;
	while(last->next != NULL){
		last = last->next;
	}
	*pelem = last->elem;
	return 0;
}
//根据值key来查找   返回-1表示没有该值  否则返回位置 
int slinket_list_find(SLinketList head,ETYPE *pelem){
	struct Node *node = head->next;
	size_t i;
	for(i=0;node!=NULL;node=node->next,i++){
		if(node->elem == *pelem){
			return i;
		} 
	}
	return -1;
}
//遍历单向链表
void slinket_list_travel(SLinketList head,void (*travel)(int)){
	struct Node *node = head->next;
	while(node!=NULL){
		travel(node->elem);
		node = node->next;
	}
}

//删除所有元素  清空所有元素 
void slinket_list_clear(SLinketList head){
	struct Node *node,*next;
	for(node=head->next;node!=NULL;node=next){
		next = node->next;//提前保存node后面一个节点的位置 
		free(node);//释放node所指向的结点内存 
	}
	head->next = NULL;
}
//销毁单向链表
void slinket_list_destroy(SLinketList head){
	slinket_list_clear(head);
	free(head);//释放头结点的内存空间 
} 

//单向链表逆序
void slinket_list_reverse(SLinketList head){
	//没有结点 或者 只有一个结点 不需要做任何事情  
	if(head->next == NULL || head->next->next == NULL){
		return;
	}
	struct Node *prev = NULL;
	struct Node *curr = head->next;
	struct Node *next = NULL;
	while(curr!=NULL){
		next = curr->next; //保存当前结点的下一个结点的位置
		curr->next = prev; //逆转当前curr结点  指向原来的前结点
		prev = curr;
		curr = next; 
	}
	head->next = prev;
}
//获取倒数第n个元素
int slinket_list_get_last(SLinketList head,size_t pos,ETYPE *pelem){
	struct Node *front = head->next;
	struct Node *back = head->next;
	size_t i;
	for(i=1;front!=NULL&&i<pos;i++){
		front = front->next;//先让front先走pos-1步 
	}
	if(front == NULL){
		return -1;
	}
	while(front->next!=NULL){
		front = front->next;
		back = back->next; 
	}
	//front指向最后一个  back指向前面 pos-1
	*pelem = back->elem;
	return 0; 
}
// a1,a2,a3... an-1,an    a1,an,a2,an-1,a3,an-2,...
// 1 2 3 4 5 6 7 8 9 10   1 10 2 9 3 8 4 7 5 6

void slinket_list_reset_seq(SLinketList head){
	size_t size = slinket_list_size(head);
	if(size<=2)
		return;
	size_t i;
	struct Node *node = head->next;
	for(i=0;i<size/2;i++){
		node = node->next;
	}
	//node 作为头结点一样使用 
	slinket_list_reverse(node);
	struct Node *front = node->next, *back = head->next;
	node->next = NULL;
	node = head;
	bool flag = true;
	while(front!=NULL && back!=NULL){	
		node->next = back;
		back = back->next;
		node = node->next;
		node->next = front;
		front = front->next;
		node = node->next;				
//		if(flag){
//			node->next = back;
//			back = back->next;
//		}else{
//			node->next = front;
//			front = front->next;
//		}
//		flag = !flag;
//		node = node->next;
	}
	node->next = back;	
}
// 按指定元素个数逆序  a1,a2,a3,a4,a5,a6,a7,a8   a3,a2,a1,a6,a5,a4,a8,a7
// 用递归 
void slinket_list_reverse_by_count(SLinketList head,size_t count){
	struct Node *prev = NULL;
	struct Node *curr = head->next;
	struct Node *next = NULL;
	struct Node *last = head;//上次逆转之后的最后一个结点
	struct Node *first = NULL; 
	size_t i=0;
	while(curr != NULL){
		first = curr;//记录该次逆序的第一个结点  
		for(i=0;curr!=NULL&&i<count;i++){
			next = curr->next;
			curr->next = prev;
			prev = curr;
			curr = next;
		}
		last->next = prev;//上次逆转之后最后一个结点的下一个结点应该
		last = first; 
	}
	last->next = NULL;
}



 //常考
//单向链表逆序
void slinket_list_reverse(SLinketList head){
if(head->next==NULL || head->next->next==NULL){
	return;  //没有节点或者只有一个节点,不需要做任何事情
}
struct Node *prev=NULL;
struct Node *curr=head->next;
struct Node *next=NULL;
while(curr!=NULL){
	next = curr->next;//保存当前节点的下一个节点,因为下一步这个信息就被替换了
	curr->next=prev;//逆转当前节点,指向原来的前节点
	prev=curr;
	curr=next;
}	
	head->next=prev;//curr==NULL的时候,prev就是最后一个的位置
}

	//获取倒数第n个元素
int slinket_list_get_last(SLinketList head,size_t pos,ETYPE *pelem){
	struct Node *front=head->next;
	struct Node *back=head->next;
	size_t i;
	for(i=1;front!=NULL && i<pos;i++){
		front=front->next;  //先让front先走pos-1步
	}
	if(front==NULL){
		return -1;
	}
	while(front=NULL){
		front=front->next;
		back=back->next;
	}//front循环结束指向最后一个的下一个即NULL
	*pelem=back->elem;
	return 0;
}
	
void slinket_list_reset_seq(SLinketList head);
按指定元素个数逆序    a1 a2

void slinket_list_reverse_by_count(SLinketList head,size_t count)

万能模板
main.c

#include <stdio.h>
#include <stdlib.h>
#include "slinkedlist.h"

typedef struct Stu{
	int no;
	char name[40];
	int score[3];
}Stu; 

int comp_no(const void *v1,const void *v2){
	const struct Stu *ps1 = (const struct Stu *)v1;
	const struct Stu *ps2 = (const struct Stu *)v2;
	return ps1->no - ps2->no;
}
int comp_name(const void *v1,const void *v2){
	const struct Stu *ps1 = (const struct Stu *)v1;
	const struct Stu *ps2 = (const struct Stu *)v2;
	return strcmp(ps1->name,ps2->name);
}


void show_stu(const void *pv){
	const Stu *pstu = (const Stu *)pv;
	printf("%d  %s  %d %d %d\n",
		pstu->no,pstu->name,pstu->score[0],pstu->score[1],pstu->score[2]);
}

int main(int argc, char *argv[]) {
	SLinkedList list = slinked_list_create(sizeof(struct Stu));
	struct Stu stus[]={
		{110,"余华康",{54,67,40}},
		{120,"杨承杰",{78,67,90}},
		{119,"王涵",{60,83,100}},
		{127,"陈圣泽",{67,87,99}},
		{101,"周涵",{80,82,90}}
	};
	size_t i,len = sizeof(stus)/sizeof(stus[0]);
	for(i=0;i<len;i++){
		slinked_list_insert(list,i/2,(const void*)&stus[i]);
	} 
	printf("size:%u\n",slinked_list_size(list));
	struct Stu s ={100,"李子璇",{87,70,60}};
	slinked_list_insert(list,3,&s);
	printf("size:%u\n",slinked_list_size(list));
	slinked_list_travel(list,show_stu);	
	slinked_list_delete(list,3,&s);
	show_stu(&s);
	printf("------------\n");
	slinked_list_travel(list,show_stu);
	struct Stu sf = {110};
	struct Stu *ps = slinked_list_find(list,&sf,comp_no);
	if(ps == NULL){
		printf("没有找到!\n");
	}else{
		printf("找到了:");
		show_stu(ps); 
	}
	
	strcpy(sf.name,"王涵");
	ps = slinked_list_find(list,&sf,comp_name);
	if(ps == NULL){
		printf("没有找到!\n");
	}else{
		printf("找到了:");
		show_stu(ps); 
	}	
	slinked_list_destroy(list);
	return 0;
}

.h

#ifndef SLINKED_LIST_H__
#define SLINKED_LIST_H__

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <stdbool.h>

typedef struct Node{
	void *pelem;          //malloc
	struct Node *next;    //存储下一个结点的位置 
}SNode;


typedef struct SLinkedList{
	struct Node *head;    //头结点
	size_t elemSize;      //每个元素的大小
	size_t size;          //链表元素的个数 
}*SLinkedList; 

#define NODESIZE  sizeof(struct Node)
#define LISTSIZE  sizeof(struct SLinkedList)

SLinkedList slinked_list_create(size_t elemSize);
bool slinked_list_empty(SLinkedList list);
size_t slinked_list_size(SLinkedList list);
void slinked_list_clear(SLinkedList list);
void slinked_list_destroy(SLinkedList list);
void slinked_list_travel(SLinkedList list,void (*travel)(const void *));
int slinked_list_insert(SLinkedList list,size_t pos,const void *pelem);
int slinked_list_delete(SLinkedList list,size_t pos,void *pelem);
int slinked_list_get(SLinkedList list,size_t pos,void *pelem);
void *slinked_list_index(SLinkedList list,size_t pos); 
void *slinked_list_find(SLinkedList list,const void *key,int (*cmp)(const void*,const void*));

#endif //SLINKED_LIST_H__

.c

#include "slinkedlist.h"
/*
typedef struct Node{
	void *pelem;          //malloc
	struct Node *next;    //存储下一个结点的位置 
}SNode;


typedef struct SLinkedList{
	struct Node *head;    //头结点
	size_t elemSize;      //每个元素的大小
	size_t size;          //链表元素的个数 
}*SLinkedList; 
*/
//SLinkedList list = slinked_list_create(8); 
SLinkedList slinked_list_create(size_t elemSize){
	SLinkedList list = (SLinkedList)malloc(LISTSIZE);
	if(list == NULL){
		return NULL;
	}
	list->head = (struct Node*)malloc(NODESIZE);//头结点
	if(list->head == NULL){
		free(list);
		return NULL;
	} 
	list->head->next = NULL;
	list->elemSize = elemSize;
	list->size = 0;
	return list;
}
bool slinked_list_empty(SLinkedList list){
	return list->size == 0;
}
size_t slinked_list_size(SLinkedList list){
	return list->size;
}
void slinked_list_clear(SLinkedList list){
	struct Node *node = list->head->next;//第一个结点 
	struct Node *next = NULL;
	while(node != NULL){
		next = node->next;
		free(node->pelem);   //释放存储数据元素的内存空间 
		free(node);          //释放结点的内存空间 
		node = next; 
	} 
	list->head = NULL;
}
void slinked_list_destroy(SLinkedList list){
	slinked_list_clear(list);
	free(list->head);//list->head = NULL; list->size = 0; 
	free(list);
}
void slinked_list_travel(SLinkedList list,void (*travel)(const void *)){
	struct Node *node = list->head->next;
	for(;node!=NULL;node = node->next){
		travel(node->pelem);
	}
}
//pos [1,...]
static struct Node *slinked_list_get_prev_node(SLinkedList list,size_t pos){
	struct Node *node = list->head;
	size_t i;
	for(i=0;node!=NULL&&i<pos;i++){
		node = node->next;
	}
	return node;
} 
int slinked_list_insert(SLinkedList list,size_t pos,const void *pelem){
	struct Node *prev = slinked_list_get_prev_node(list,pos);
	if(prev == NULL){
		return -1;
	}
	struct Node *node = (struct Node*)malloc(NODESIZE);
	if(node == NULL){
		return -2;
	}
	node->pelem = malloc(list->elemSize);
	if(node->pelem == NULL){
		free(node);
		return -3;
	}
	memcpy(node->pelem,pelem,list->elemSize);//内存拷贝 
	node->next = prev->next;
	prev->next = node;
	list->size++;
	return 0;
}
int slinked_list_delete(SLinkedList list,size_t pos,void *pelem){
	struct Node *prev = slinked_list_get_prev_node(list,pos);
	if(prev==NULL||prev->next==NULL){
		return -1;
	} 
	struct Node *curr = prev->next;
	memcpy(pelem,curr->pelem,list->elemSize);
	prev->next = curr->next;
	--list->size;
	free(curr->pelem);//存储数据的内存可以释放了
	free(curr);
	return 0;
}
int slinked_list_get(SLinkedList list,size_t pos,void *pelem){
	struct Node *curr = slinked_list_get_prev_node(list,pos+1);
	if(curr == NULL){
		return -1;
	}
	memcpy(pelem,curr->pelem,list->elemSize);
	return 0;
}
void *slinked_list_index(SLinkedList list,size_t pos){
	struct Node *node = slinked_list_get_prev_node(list,pos);
	if(node == NULL){
		return NULL;
	}
	return node->pelem;
}

void *slinked_list_find(SLinkedList list,const void *key,int (*cmp)(const void*,const void*)){
	struct Node *node = list->head->next;
	for(;node!=NULL;node = node->next){
		if(cmp(key,node->pelem)==0){
			return node->pelem;
		}
	}
	return NULL;
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-15 16:28:07  更:2021-07-15 16:28:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 16:22:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码