美文网首页
数据结构--单向循环链表

数据结构--单向循环链表

作者: Bean_Nan | 来源:发表于2017-04-16 22:50 被阅读0次
#include <stdio.h>
#include <stdlib.h>

typedef struct Node {
    int data;
    struct Node *next;
}Node, *LinkedList;

LinkedList insert(LinkedList head, Node *node, int index) {
    if (head == NULL) {
        if (index != 0) {
            return head;
        }
        head = node;
        head->next = head;
    }
    //head在这里其实已经不能称之为头结点,尾结点应该更合适一些
    if (index == 0) {
        node->next = head->next;
        head->next = node;
        return head;
    }
    Node *current_node = head->next;
    int count = 0;
    //在循环列表中所有结点的下一个结点是不可能为空的,所有循环条件得进行变更
    while (current_node != head && count < count - 1) {
        current_node = current_node->next;
        count++;
    }
    if (count == index - 1) {
        node->next = current_node->next;
        current_node->next = node;
    }
    //如果这个结点插入的位置正好是尾结点的后一个位置,那么要对尾结点进行更新
    if (node == head->next) {
       head = node;
    }

    return head;
}
//删除结点
LinkedList delete_node(LinkedList head, int index) {
    if (head == NULL) {
        return head;
    }
    //删除头结点
    if (index == 0) {
        Node *delete_node = head->next;
        head->next = delete_node->next;
        free(delete_node);
        return head;
    }
    Node *current_node = head->next;
    int count = 0;

    while (current_node != head && count < index - 1) {
        current_node = current_node->next;
        count++;
    }
    if (count == index - 1) {
        Node *delete_node = current_node->next;
        current_node->next = delete_node->next;
        free(delete_node);
    }

    return head;

}
//循环列表反转
LinkedList reverse(LinkedList head) {
    if (head == NULL) {
        return head;
    }
    Node *current_node, *next_node, *top_node;
    current_node = head->next->next;
    head->next->next = head;
    top_node = head->next;
    while (current_node != top_node) {
        next_node = current_node->next;
        current_node->next = head->next;
        head->next = current_node;
        current_node = next_node;
    }

    return head;
}

int main() {

    return 0;
}


相关文章

  • 线性表-单向循环链表

    单向循环链表 单向循环链表示意图如下: 数据结构定义(同普通链表) 单向循环链表初始化与赋值 在上面循环遍历查找尾...

  • 数据结构笔记

    数据结构课程概览 ================== 1.顺序表 2.链表:单链表,单向循环链表,双链表...

  • 线性表-单向循环链表

    为了方便,本文介绍的单向循环链表不包含头节点 单向循环链表内容 单向循环链表的的定义 单向循环链表的创建 单向循环...

  • 10.单向循环链表SingleCycleLinkList

    目录:1.单向循环链表的定义2.单向循环链表的图解3.单向循环链表定义操作4.单向循环链表的实现 1.单向循环链表...

  • 数据结构与算法之循环链表(3.4)

    目录 单向循环链表双向循环链表约瑟夫问题如何发挥循环链表的最大威力? 一 单向循环链表 单向循环链表 - 只有一个...

  • 04单向循环链表实现总结

    一、说说什么是单向循环链表? 人狠话不多. 上图. 单向循环链表就是这个样子!单向循环链表.png 与单向链表区别...

  • 数据结构基础--单向循环链表

    单向循环链表 单向循环链表是可循环的单链表,它与单链表的区别在于单向链表的最后一个元素的指针域为空,而单向循环链表...

  • 数据结构与算法——线性表3

    线性表——单向循环链表 3、单向循环链表 在单向链表的基础上,单向链表的尾结点的Next指向链表的头部,就是为循环...

  • 数据结构与算法(第一季):循环链表

    一、单向循环链表 尾节点的next,指向头节点。 二、单向循环链表接口设计 相较于单项链表,单向循环链表需要重写插...

  • 数据结构

    数据结构 队列&栈&链表&集合&hash表&树&图 队列 先进先出 栈 先进后出 链表 单向链表 双向链表 循环链...

网友评论

      本文标题:数据结构--单向循环链表

      本文链接:https://www.haomeiwen.com/subject/bfjzattx.html