📜  计算循环链表中的节点

📅  最后修改于: 2022-05-13 01:57:45.473000             🧑  作者: Mango

计算循环链表中的节点

给定一个循环链表,计算其中的节点数。例如,以下列表的输出为 5。

我们使用循环链表中使用的概念 |设置 2(遍历)。在遍历时,我们会跟踪节点的数量。

C++
//  c++  program to count number of nodes in
// a circular linked list.
#include 
using namespace std;
 
/*structure for a node*/
 
struct Node {
    int data;
    Node* next;
    Node(int x)
    {
        data = x;
        next = NULL;
    }
};
/* Function to insert a node at the beginning
of a Circular linked list */
struct Node* push(struct Node* last, int data)
{
    if (last == NULL) {
        struct Node* temp
            = (struct Node*)malloc(sizeof(struct Node));
 
        // Assigning the data.
        temp->data = data;
        last = temp;
        // Note : list was empty. We link single node
        // to itself.
        temp->next = last;
 
        return last;
    }
 
    // Creating a node dynamically.
    struct Node* temp
        = (struct Node*)malloc(sizeof(struct Node));
 
    // Assigning the data.
    temp->data = data;
 
    // Adjusting the links.
    temp->next = last->next;
    last->next = temp;
 
    return last;
}
 
/* Function to  count  nodes in a given Circular
linked list */
 
int countNodes(Node* head)
{
    Node* temp = head;
    int result = 0;
    if (head != NULL) {
        do {
            temp = temp->next;
            result++;
        } while (temp != head);
    }
 
    return result;
}
 
/* Driver program to test above functions */
int main()
{
    /* Initialize lists as empty */
    Node* head = NULL;
    head = push(head, 12);
    head = push(head, 56);
    head = push(head, 2);
    head = push(head, 11);
    cout << countNodes(head);
    return 0;
}
 
// This code is contributed by anushikaseth.


Java
// Java program to count number of nodes in
// a circular linked list.
class GFG
{
 
/* ure for a node */
static class Node
{
    int data;
    Node next;
};
 
/* Function to insert a node at the beginning
of a Circular linked list */
static Node push( Node head_ref, int data)
{
    Node ptr1 = new Node();
    Node temp = head_ref;
    ptr1.data = data;
    ptr1.next = head_ref;
 
    /* If linked list is not null then set
    the next of last node */
    if (head_ref != null)
    {
        while (temp.next != head_ref)
            temp = temp.next;
        temp.next = ptr1;
    } else
        ptr1.next = ptr1; /*For the first node */
 
    head_ref = ptr1;
    return head_ref;
}
 
/* Function to print nodes in a given Circular
linked list */
static int countNodes( Node head)
{
    Node temp = head;
    int result = 0;
    if (head != null)
    {
        do
        {
            temp = temp.next;
            result++;
        } while (temp != head);
    }
 
    return result;
}
 
/* Driver program to test above functions */
public static void main(String args[])
{
    /* Initialize lists as empty */
    Node head = null;
    head = push(head, 12);
    head = push(head, 56);
    head = push(head, 2);
    head = push(head, 11);
 
    System.out.printf("%d", countNodes(head));
}
}
 
// This code is contributed by Arnab Kundu


Python3
# Python3 program to count number of nodes in
# a circular linked list.
 
# structure for a node
class Node:
    def __init__(self, data):
        self.data = data
        self.next = None
 
# Function to insert a node at the beginning
# of a Circular linked list */
def push(head_ref,data):
 
    ptr1 = Node(0)
    temp = head_ref
    ptr1.data = data
    ptr1.next = head_ref
 
    # If the linked list is not None then set
    # the next of last node
    if (head_ref != None) :
        while (temp.next != head_ref):
            temp = temp.next
        temp.next = ptr1
    else:
        ptr1.next = ptr1 #For the first node */
 
    head_ref = ptr1
    return head_ref
 
# Function to print nodes
# in a given Circular linked list
def countNodes(head):
 
    temp = head
    result = 0
    if (head != None) :
        while True :
            temp = temp.next
            result = result + 1
            if (temp == head):
                break
     
    return result
 
# Driver Code
if __name__=='__main__':
 
    # Initialize lists as empty */
    head = None
    head = push(head, 12)
    head = push(head, 56)
    head = push(head, 2)
    head = push(head, 11)
 
    print( countNodes(head))
     
# This code is contributed by Arnab Kundu


C#
// C# program to count number of nodes in
// a circular linked list.
using System;
 
class GFG
{
 
/* structure for a node */
public class Node
{
    public int data;
    public Node next;
};
 
/* Function to insert a node at the beginning
of a Circular linked list */
static Node push( Node head_ref, int data)
{
    Node ptr1 = new Node();
    Node temp = head_ref;
    ptr1.data = data;
    ptr1.next = head_ref;
 
    /* If linked list is not null then set
    the next of last node */
    if (head_ref != null)
    {
        while (temp.next != head_ref)
            temp = temp.next;
        temp.next = ptr1;
    } else
        ptr1.next = ptr1; /*For the first node */
 
    head_ref = ptr1;
    return head_ref;
}
 
/* Function to print nodes in a given Circular
linked list */
static int countNodes( Node head)
{
    Node temp = head;
    int result = 0;
    if (head != null)
    {
        do
        {
            temp = temp.next;
            result++;
        } while (temp != head);
    }
 
    return result;
}
 
/* Driver code */
public static void Main(String []args)
{
    /* Initialize lists as empty */
    Node head = null;
    head = push(head, 12);
    head = push(head, 56);
    head = push(head, 2);
    head = push(head, 11);
 
    Console.Write( countNodes(head));
}
}
 
// This code is contributed by Arnab Kundu


Javascript


输出:

4

如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程学生竞争性编程现场课程