数据结构循环链表之循环链表遍历 | 第三套

简介: 数据结构循环链表之循环链表遍历 | 第三套

我们在上一篇关于循环链表的文章中讨论了循环链表的介绍和应用。在这篇文章中,讨论遍历操作

在传统的链表中,我们从头节点开始遍历链表,当我们到达 NULL 时停止遍历。在循环链表中,当我们再次到达第一个节点时,我们停止遍历。以下是链表遍历的 C++ 代码。

void printList(Node* head)
{
  Node* temp = head;
  if (head != NULL) {
    do {
      cout << temp->data << " ";
      temp = temp->next;
    } while (temp != head);
  }
}

完整的程序来演示遍历。 以下是演示循环链表遍历的完整程序。

#include <bits/stdc++.h>
using namespace std;
/* 节点结构 */
class Node
{
  public:
  int data;
  Node *next;
};
/* 在循环链表的开头插入一个节点的函数 */
void push(Node **head_ref, int data)
{
  Node *ptr1 = new Node();
  Node *temp = *head_ref;
  ptr1->data = data;
  ptr1->next = *head_ref;
        /* 如果链表不为 NULL 则设置最后一个节点的下一个 */
  if (*head_ref != NULL)
  {
    while (temp->next != *head_ref)
      temp = temp->next;
    temp->next = ptr1;
  }
  else
    ptr1->next = ptr1; /*对于第一个节点*/
  *head_ref = ptr1;
}
/* 在给定的循环链表中打印节点的函数 */
void printList(Node *head)
{
  Node *temp = head;
  if (head != NULL)
  {
    do
    {
      cout << temp->data << " ";
      temp = temp->next;
    }
    while (temp != head);
  }
}
/* 测试上述功能的驱动程序 */
int main()
{
        /* 初始化列表为空 */
  Node *head = NULL;
        /* 创建的链表将是 11->2->56->12 */
  push(&head, 12);
  push(&head, 56);
  push(&head, 2);
  push(&head, 11);
  cout << "循环列表内容\n ";
  printList(head);
  return 0;
}

输出:

循环列表内容
11 2 56 12


目录
相关文章
|
18天前
|
存储 Java
数据结构第三篇【链表的相关知识点一及在线OJ习题】
数据结构第三篇【链表的相关知识点一及在线OJ习题】
22 7
|
18天前
|
存储 安全 Java
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
20 3
|
17天前
|
算法 Java
数据结构与算法学习五:双链表的增、删、改、查
双链表的增、删、改、查操作及其Java实现,并通过实例演示了双向链表的优势和应用。
12 0
数据结构与算法学习五:双链表的增、删、改、查
|
10天前
|
存储
[数据结构] -- 双向循环链表
[数据结构] -- 双向循环链表
16 0
|
16天前
|
存储
探索数据结构:便捷的双向链表
探索数据结构:便捷的双向链表
|
16天前
|
存储
探索数据结构:单链表的实践和应用
探索数据结构:单链表的实践和应用
|
16天前
|
存储 算法
数据结构与算法学习十六:树的知识、二叉树、二叉树的遍历(前序、中序、后序、层次)、二叉树的查找(前序、中序、后序、层次)、二叉树的删除
这篇文章主要介绍了树和二叉树的基础知识,包括树的存储方式、二叉树的定义、遍历方法(前序、中序、后序、层次遍历),以及二叉树的查找和删除操作。
16 0
|
17天前
|
算法 Java
数据结构与算法学习六:单向环形链表应用实例的约瑟夫环问题
这篇文章通过单向环形链表的应用实例,详细讲解了约瑟夫环问题的解决方案,并提供了Java代码实现。
12 0
|
5月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
5月前
|
存储 SQL 算法
LeetCode 题目 86:分隔链表
LeetCode 题目 86:分隔链表