数据结构---单链表

发布于:2024-05-05 ⋅ 阅读:(107) ⋅ 点赞:(0)
  • 题目:构造一个单链表。

  • 使用的软件:VS2022
  • 使用的语言:C语言
  • 使用的项目:test.c 

                             Setlist.h

                             Setlish.c

  • 项目实践: Setlist.h的代码为:
    #pragma once
    
    #include<stdio.h>
    #include<stdlib.h>
    #include<assert.h>
    
    //定义节点的结构
    //数据 + 指向下一个节点的指针
    typedef int SLTDataType;
    
    typedef struct SListNode {
    	SLTDataType data;
    	struct SListNode* next;
    }SLTNode;
    
    void SLTPrint(SLTNode* phead);
    
    //尾插
    void SLTPushBack(SLTNode** pphead, SLTDataType x);
    //头插
    void SLTPushFront(SLTNode** pphead, SLTDataType x);
    //尾删
    void SLTPopBack(SLTNode** pphead);
    //头删
    void SLTPopFront(SLTNode** pphead);
    

    它和顺序表的头文件基本上差不多,

  • Setlish.c的主文件,则代码为:

    #define  _CRT_SECURE_NO_WARNINGS 1
    
    #include"SList.h"
    void SLTPrint(SLTNode* phead)
    {
    	SLTNode* pcur = phead;
    	while (pcur)//pcur != NULL
    	{
    		printf("%d->", pcur->data);
    		pcur = pcur->next;
    	}
    	printf("NULL\n");
    }
    
    SLTNode* SLTBuyNode(SLTDataType x)
    {
    	SLTNode* newnode = (SLTNode*)malloc(sizeof(SLTNode));
    	if (newnode == NULL)
    	{
    		perror("malloc fail!");
    		exit(1);
    	}
    	newnode->data = x;
    	newnode->next = NULL;
    
    	return newnode;
    }
    
    //尾插
    void SLTPushBack(SLTNode** pphead, SLTDataType x)
    {
    	assert(pphead);
    	//*pphead 就是指向第一个节点的指针
    	//空链表和非空链表
    	SLTNode* newnode = SLTBuyNode(x);
    	if (*pphead == NULL)
    	{
    		*pphead = newnode;
    	}
    	else
    	{
    		//找尾
    		SLTNode* ptail = *pphead;
    		while (ptail->next)
    		{
    			ptail = ptail->next;
    		}
    		//ptail指向的就是尾结点
    		ptail->next = newnode;
    	}
    }
    //头插
    void SLTPushFront(SLTNode** pphead, SLTDataType x)
    {
    	assert(pphead);
    	SLTNode* newnode = SLTBuyNode(x);
    	//newnode *pphead
    	newnode->next = *pphead;
    	*pphead = newnode;
    }
    //尾删
    void SLTPopBack(SLTNode** pphead)
    {
    	//链表不能为空
    	assert(pphead && *pphead);
    	//链表只有一个节点
    	if ((*pphead)->next == NULL) //-> 优先级高于*
    	{
    		free(*pphead);
    		*pphead = NULL;
    	}
    	else {
    		//链表有多个节点
    
    		SLTNode* prev = *pphead;
    		SLTNode* ptail = *pphead;
    		while (ptail->next)
    		{
    			prev = ptail;
    			ptail = ptail->next;
    		}
    		//prev ptail
    		free(ptail);
    		ptail = NULL;
    		prev->next = NULL;
    	}
    }
    //头删
    void SLTPopFront(SLTNode** pphead);

    这里就直接写完了,不做过多的解释,请看vcr

  • test.c的代码:

    #define  _CRT_SECURE_NO_WARNINGS 1
    
    
    #include"SList.h"
    
    void SListTest01()
    {
    	//链表是由一个一个的节点组成
    	//创建几个节点
    	SLTNode* node1 = (SLTNode*)malloc(sizeof(SLTNode));
    	node1->data = 1;
    
    	SLTNode* node2 = (SLTNode*)malloc(sizeof(SLTNode));
    	node2->data = 2;
    
    	SLTNode* node3 = (SLTNode*)malloc(sizeof(SLTNode));
    	node3->data = 3;
    
    	SLTNode* node4 = (SLTNode*)malloc(sizeof(SLTNode));
    	node4->data = 4;
    
    	//将四个节点连接起来
    	node1->next = node2;
    	node2->next = node3;
    	node3->next = node4;
    	node4->next = NULL;
    
    	//调用链表的打印
    	SLTNode* plist = node1;
    	SLTPrint(plist);
    }
    
    void SListTest02()
    {
    	SLTNode* plist = NULL;
    	SLTPushBack(&plist, 1);
    	SLTPushBack(&plist, 2);
    	SLTPushBack(&plist, 3);
    	SLTPushBack(&plist, 4);
    	SLTPrint(plist);
    	//SLTPushBack(NULL, 5);
    	//
    	//测试头插
    	//SLTPushFront(&plist, 6);
    	//SLTPrint(plist);
    	//SLTPushFront(&plist, 7);
    	//SLTPrint(plist);
    	//SLTPushFront(&plist, 8);
    	//SLTPrint(plist);
    
    	//测试尾删
    	SLTPopBack(&plist);
    	SLTPrint(plist);
    	SLTPopBack(&plist);
    	SLTPrint(plist);
    	SLTPopBack(&plist);
    	SLTPrint(plist);
    	SLTPopBack(&plist);
    	SLTPrint(plist);
    
    }
    
    int main()
    {
    	//SListTest01();
    	SListTest02();
    	return 0;
    }

    基本上就这么多,如果要解释,就是越解释越乱,请大家仔细观看。