循环链表(单、双)

本文介绍了如何实现循环单链表和循环双链表,包括初始化、判断空表、检查表尾结点等操作。示例代码使用C++编写,详细展示了数据结构中的基本操作。
摘要由CSDN通过智能技术生成

一、循环单链表


//循环单链表
#include <stdio.h>
#include <stdlib.h>    //malloc、free函数的头文件
typedef struct LNode{    //定义单链表结点类型
    int data;          //每个结点存放一个数据元素
    struct LNode *next;      //指针指向下一个结点
}LNode,*LinkList;

//初始化循环单链表
bool InitList(LinkList &L){
    L = (LNode *)malloc(sizeof(LNode));    //分配一个头结点
    if(L == NULL) return false;      //内存不足分配失败
    L->next=L;           //头结点next指向头结点
    return true;
}

//判断循环单链表是否为空
bool Empty(LinkList L){
    if(L->next==L)
        return true;
    else
        return false;
}

//判断结点p是否为循环单链表的表尾结点
bool isTail(LinkList L,LNode *p){
    if(p->next==L)
        return true;
    else
        return false;
}

int main(){
    LinkList L;        //声明一个单链表的指针
    In

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值