Given a linked list and a key ‘X‘ in, the task is to check if X is present in the linked list or not.
Examples:
Input: 14->21->11->30->10, X = 14
Output: Yes
Explanation: 14 is present in the linked list.Input: 6->21->17->30->10->8, X = 13
Output: No
Using O(N) Extra Space.
The Approach:
In this approach we use vector where we store all the nodes value in the vector and then check whether there is key present in vector then it will return 1.
C++
| #include <bits/stdc++.h>usingnamespacestd;  /* Link list node */classNode {public:    intkey;    Node* next;};  /* Given a reference (pointer to pointer) to the headof a list and an int, push a new node on the frontof the list. */voidpush(Node** head_ref, intnew_key){    /* allocate node */    Node* new_node = newNode();      /* put in the key */    new_node->key = new_key;      /* link the old list of the new node */    new_node->next = (*head_ref);      /* move the head to point to the new node */    (*head_ref) = new_node;}intmain() {     /* Start with the empty list */    Node* head = NULL;    intx = 21;      /* Use push() to construct below list    14->21->11->30->10 */    push(&head, 10);    push(&head, 30);    push(&head, 11);    push(&head, 21);    push(&head, 14);    vector<int>v;    //we donot use given data     Node* temp=head;    while(temp!=NULL){     v.push_back(temp->key);     temp=temp->next;    }    // we use iterator to find.    vector<int>::iterator it;    find(v.begin(),v.end(),x);    if(it==v.end()){      cout<<"NO"<<endl;    }else{     cout<<"YES"<<endl;    }    return0;} | 
Java
| importjava.util.*;classNode {  intkey;  Node next;  Node(intkey) {    this.key = key;    this.next = null;  }}classMain {    // Given a reference (pointer to pointer) to the head   // of a list and an int, push a new node on the front of the list.  staticvoidpush(Node[] head_ref, intnew_key) {    Node new_node = newNode(new_key);    new_node.next = head_ref[0];    head_ref[0] = new_node;  }  publicstaticvoidmain(String[] args) {    Node[] head = newNode[1];    intx = 21;    // Use push() to construct below list 14->21->11->30->10    push(head, 10);    push(head, 30);    push(head, 11);    push(head, 21);    push(head, 14);    // Create a vector of integers from the linked list and search for the value x in the vector using an iterator.    Vector<Integer> v = newVector<Integer>();    Node temp = head[0];    while(temp != null) {      v.add(temp.key);      temp = temp.next;    }    intit = v.indexOf(x);    if(it == -1) {      System.out.println("NO");    } else{      System.out.println("YES");    }  }} | 
Python3
| # Class definition for NodeclassNode:    # Initialize the node with a key    def__init__(self, key):        self.key =key        self.next=None  # Class definition for Linked ListclassLinkedList:    # Initialize the linked list with a head node    def__init__(self):        self.head =None      # Add a new node with key "new_key" at the beginning of the linked list    defpush(self, new_key):        new_node =Node(new_key)        new_node.next=self.head        self.head =new_node  # Create a linked list objectllist =LinkedList()# Add new nodes to the linked listllist.push(10)llist.push(30)llist.push(11)llist.push(21)llist.push(14)  # Key to search for in the linked listx =21# Create a temp variable to traverse the linked listtemp =llist.head# List to store the keys in the linked listv =[]# Traverse the linked list and store the keys in the list "v"while(temp):    v.append(temp.key)    temp =temp.next  # Check if "x" is in the list "v"ifx inv:    print("YES")else:    print("NO") | 
C#
| usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;/* Link list node */classNode {    publicintkey;    publicNode next;};classProgram {    /* Given a reference (pointer to pointer) to the head    of a list and an int, push a new node on the front    of the list. */    staticvoidpush(refNode head_ref, intnew_key)    {        /* allocate node */        Node new_node = newNode();        /* put in the key */        new_node.key = new_key;        /* link the old list of the new node */        new_node.next = head_ref;        /* move the head to point to the new node */        head_ref = new_node;    }    staticvoidMain(string[] args)    {        /* Start with the empty list */        Node head = null;        intx = 21;        /* Use push() to construct below list        14->21->11->30->10 */        push(refhead, 10);        push(refhead, 30);        push(refhead, 11);        push(refhead, 21);        push(refhead, 14);        List<int> v = newList<int>();        Node temp = head;        while(temp != null) {            v.Add(temp.key);            temp = temp.next;        }        /* Find whether x is present in the list or not */        if(v.Contains(x)) {            Console.WriteLine("YES");        }        else{            Console.WriteLine("NO");        }    }}// This code is contributed by sarojmcy2e | 
Javascript
| // Class definition for Nodeclass Node {// Initialize the node with a keyconstructor(key) {this.key = key;this.next = null;}}// Class definition for Linked Listclass LinkedList {// Initialize the linked list with a head nodeconstructor() {this.head = null;}// Add a new node with key "new_key" at the beginning of the linked listpush(new_key) {let new_node = newNode(new_key);new_node.next = this.head;this.head = new_node;}}// Create a linked list objectlet llist = newLinkedList();// Add new nodes to the linked listllist.push(10);llist.push(30);llist.push(11);llist.push(21);llist.push(14);// Key to search for in the linked listlet x = 22;// Create a temp variable to traverse the linked listlet temp = llist.head;// Array to store the keys in the linked listlet v = [];// Traverse the linked list and store the keys in the array "v"while(temp) {v.push(temp.key);temp = temp.next;}// Check if "x" is in the array "v"if(v.includes(x)) {console.log("YES");} else{console.log("NO");} | 
YES
Time Complexity: O(N), to traverse linked list.
Auxiliary Space: O(N),to store the values.
Search an element in a Linked List (Iterative Approach):
Follow the below steps to solve the problem:
- Initialize a node pointer, current = head.
- Do following while current is not NULL
- If the current value (i.e., current->key) is equal to the key being searched return true.
- Otherwise, move to the next node (current = current->next).
 
- If the key is not found, return false
Below is the implementation of the above approach.
C++
| // Iterative C++ program to search// an element in linked list#include <bits/stdc++.h>usingnamespacestd;/* Link list node */classNode {public:    intkey;    Node* next;};/* Given a reference (pointer to pointer) to the headof a list and an int, push a new node on the frontof the list. */voidpush(Node** head_ref, intnew_key){    /* allocate node */    Node* new_node = newNode();    /* put in the key */    new_node->key = new_key;    /* link the old list of the new node */    new_node->next = (*head_ref);    /* move the head to point to the new node */    (*head_ref) = new_node;}/* Checks whether the value x is present in linked list */boolsearch(Node* head, intx){    Node* current = head; // Initialize current    while(current != NULL) {        if(current->key == x)            returntrue;        current = current->next;    }    returnfalse;}/* Driver code*/intmain(){    /* Start with the empty list */    Node* head = NULL;    intx = 21;    /* Use push() to construct below list    14->21->11->30->10 */    push(&head, 10);    push(&head, 30);    push(&head, 11);    push(&head, 21);    push(&head, 14);      // Function call    search(head, x) ? cout << "Yes": cout << "No";    return0;}// This is code is contributed by rathbhupendra | 
C
| // Iterative C program to search an element// in the linked list#include <stdbool.h>#include <stdio.h>#include <stdlib.h>/* Link list node */structNode {    intkey;    structNode* next;};/* Given a reference (pointer to pointer) to the head  of a list and an int, push a new node on the front  of the list. */voidpush(structNode** head_ref, intnew_key){    /* allocate node */    structNode* new_node        = (structNode*)malloc(sizeof(structNode));    /* put in the key  */    new_node->key = new_key;    /* link the old list of the new node */    new_node->next = (*head_ref);    /* move the head to point to the new node */    (*head_ref) = new_node;}/* Checks whether the value x is present in linked list */boolsearch(structNode* head, intx){    structNode* current = head; // Initialize current    while(current != NULL) {        if(current->key == x)            returntrue;        current = current->next;    }    returnfalse;}/* Driver code*/intmain(){    /* Start with the empty list */    structNode* head = NULL;    intx = 21;    /* Use push() to construct below list     14->21->11->30->10  */    push(&head, 10);    push(&head, 30);    push(&head, 11);    push(&head, 21);    push(&head, 14);          // Function call    search(head, x) ? printf("Yes") : printf("No");    return0;} | 
Java
| // Iterative Java program to search an element// in linked list// Linked list classclassLinkedList {    Node head; // Head of list    // Inserts a new node at the front of the list    publicvoidpush(intnew_data)    {        // Allocate new node and putting data        Node new_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value x is present in linked list    publicbooleansearch(Node head, intx)    {        Node current = head; // Initialize current        while(current != null) {            if(current.data == x)                returntrue; // data found            current = current.next;        }        returnfalse; // data not found    }    // Driver code    publicstaticvoidmain(String args[])    {        // Start with the empty list        LinkedList llist = newLinkedList();        intx = 21;        /*Use push() to construct below list        14->21->11->30->10  */        llist.push(10);        llist.push(30);        llist.push(11);        llist.push(21);        llist.push(14);          // Function call        if(llist.search(llist.head, x))            System.out.println("Yes");        else            System.out.println("No");    }}// Node classclassNode {    intdata;    Node next;    Node(intd)    {        data = d;        next = null;    }}// This code is contributed by Pratik Agarwal | 
Python3
| # Iterative Python3 program to search an element# in linked list# Node classclassNode:    # Function to initialise the node object    def__init__(self, data):        self.data =data  # Assign data        self.next=None# Initialize next as null# Linked List classclassLinkedList:    def__init__(self):        self.head =None# Initialize head as None    # This function insert a new node at the    # beginning of the linked list    defpush(self, new_data):        # Create a new Node        new_node =Node(new_data)        # 3. Make next of new Node as head        new_node.next=self.head        # 4. Move the head to point to new Node        self.head =new_node    # This Function checks whether the value    # x present in the linked list    defsearch(self, x):        # Initialize current to head        current =self.head        # loop till current not equal to None        whilecurrent !=None:            ifcurrent.data ==x:                returnTrue# data found            current =current.next        returnFalse# Data Not found# Driver codeif__name__ =='__main__':    # Start with the empty list    llist =LinkedList()    x =21        ''' Use push() to construct below list        14->21->11->30->10 '''    llist.push(10)    llist.push(30)    llist.push(11)    llist.push(21)    llist.push(14)       # Function call    ifllist.search(x):        print("Yes")    else:        print("No")# This code is contributed by Ravi Shankar | 
C#
| // Iterative C# program to search an element// in linked listusingSystem;// Node classpublicclassNode {    publicintdata;    publicNode next;    publicNode(intd)    {        data = d;        next = null;    }}// Linked list classpublicclassLinkedList {    Node head; // Head of list    // Inserts a new node at the front of the list    publicvoidpush(intnew_data)    {        // Allocate new node and putting data        Node new_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value x is present in linked list    publicboolsearch(Node head, intx)    {        Node current = head; // Initialize current        while(current != null) {            if(current.data == x)                returntrue; // data found            current = current.next;        }        returnfalse; // data not found    }    // Driver code    publicstaticvoidMain(String[] args)    {        // Start with the empty list        LinkedList llist = newLinkedList();         /*Use push() to construct below list        14->21->11->30->10 */        llist.push(10);        llist.push(30);        llist.push(11);        llist.push(21);        llist.push(14);                intx = 21;        // Function call        if(llist.search(llist.head, x))            Console.WriteLine("Yes");        else            Console.WriteLine("No");    }}// This code contributed by Rajput-Ji | 
Javascript
| // Iterative javascript program // to search an element// in linked list//Node classclass Node {    constructor(d) {        this.data = d;        this.next = null;    }}// Linked list class    varhead; // Head of list    // Inserts a new node at the front of the list    functionpush(new_data)    {        // Allocate new node and putting data        varnew_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value     // x is present in linked list    functionsearch( head , x)     {        varcurrent = head; // Initialize current        while(current != null) {            if(current.data == x)                returntrue; // data found            current = current.next;        }        returnfalse; // data not found    }    // Driver function to test    // the above functions            // Start with the empty list        /*          Use push() to construct below           list 14->21->11->30->10         */        push(10);        push(30);        push(11);        push(21);        push(14);        varx = 21;        if(search(head, x))            document.write("Yes");        else            document.write("No");// This code contributed by aashish1995 | 
Yes
Time Complexity: O(N), Where N is the number of nodes in the LinkedList
Auxiliary Space: O(1)
Search an element in a Linked List (Recursive Approach):
Follow the below steps to solve the problem:
- If the head is NULL, return false.
- If the head’s key is the same as X, return true;
- Else recursively search in the next node.
Below is the recursive implementation of the above algorithm.
C++
| // Recursive C++ program to search// an element in linked list#include <bits/stdc++.h>usingnamespacestd;/* Link list node */structNode {    intkey;    structNode* next;};/* Given a reference (pointer to pointer) to the headof a list and an int, push a new node on the frontof the list. */voidpush(structNode** head_ref, intnew_key){    /* allocate node */    structNode* new_node        = (structNode*)malloc(sizeof(structNode));    /* put in the key */    new_node->key = new_key;    /* link the old list of the new node */    new_node->next = (*head_ref);    /* move the head to point to the new node */    (*head_ref) = new_node;}/* Checks whether the value x is present in linked list */boolsearch(structNode* head, intx){    // Base case    if(head == NULL)        returnfalse;    // If key is present in current node, return true    if(head->key == x)        returntrue;    // Recur for remaining list    returnsearch(head->next, x);}/* Driver code*/intmain(){    /* Start with the empty list */    structNode* head = NULL;    intx = 21;    /* Use push() to construct below list    14->21->11->30->10 */    push(&head, 10);    push(&head, 30);    push(&head, 11);    push(&head, 21);    push(&head, 14);      // Function call    search(head, x) ? cout << "Yes": cout << "No";    return0;}// This code is contributed by SHUBHAMSINGH10 | 
C
| // Recursive C program to search an element in linked list#include <stdbool.h>#include <stdio.h>#include <stdlib.h>/* Link list node */structNode {    intkey;    structNode* next;};/* Given a reference (pointer to pointer) to the head  of a list and an int, push a new node on the front  of the list. */voidpush(structNode** head_ref, intnew_key){    /* allocate node */    structNode* new_node        = (structNode*)malloc(sizeof(structNode));    /* put in the key  */    new_node->key = new_key;    /* link the old list of the new node */    new_node->next = (*head_ref);    /* move the head to point to the new node */    (*head_ref) = new_node;}/* Checks whether the value x is present in linked list */boolsearch(structNode* head, intx){    // Base case    if(head == NULL)        returnfalse;    // If key is present in current node, return true    if(head->key == x)        returntrue;    // Recur for remaining list    returnsearch(head->next, x);}/* Driver code*/intmain(){    /* Start with the empty list */    structNode* head = NULL;    intx = 21;    /* Use push() to construct below list     14->21->11->30->10  */    push(&head, 10);    push(&head, 30);    push(&head, 11);    push(&head, 21);    push(&head, 14);      // Function call    search(head, x) ? printf("Yes") : printf("No");    return0;} | 
Java
| // Recursive Java program to search an element// in the linked list// Linked list classclassLinkedList {    Node head; // Head of list    // Inserts a new node at the front of the list    publicvoidpush(intnew_data)    {        // Allocate new node and putting data        Node new_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value x is present    // in linked list    publicbooleansearch(Node head, intx)    {        // Base case        if(head == null)            returnfalse;        // If key is present in current node,        // return true        if(head.data == x)            returntrue;        // Recur for remaining list        returnsearch(head.next, x);    }    // Driver code    publicstaticvoidmain(String args[])    {        // Start with the empty list        LinkedList llist = newLinkedList();        /* Use push() to construct below list           14->21->11->30->10  */        llist.push(10);        llist.push(30);        llist.push(11);        llist.push(21);        llist.push(14);        intx = 21;          // Function call        if(llist.search(llist.head, x))            System.out.println("Yes");        else            System.out.println("No");    }}// Node classclassNode {    intdata;    Node next;    Node(intd)    {        data = d;        next = null;    }}// This code is contributed by Pratik Agarwal | 
Python3
| # Recursive Python program to# search an element in linked list# Node classclassNode:    # Function to initialise    # the node object    def__init__(self, data):        self.data =data  # Assign data        self.next=None# Initialize next as nullclassLinkedList:    def__init__(self):        self.head =None# Initialize head as None    # This function insert a new node at    # the beginning of the linked list    defpush(self, new_data):        # Create a new Node        new_node =Node(new_data)        # Make next of new Node as head        new_node.next=self.head        # Move the head to        # point to new Node        self.head =new_node    # Checks whether the value key    # is present in linked list    defsearch(self, li, key):        # Base case        if(notli):            returnFalse        # If key is present in        # current node, return true        if(li.data ==key):            returnTrue        # Recur for remaining list        returnself.search(li.next, key)# Driver Codeif__name__ =='__main__':    li =LinkedList()    li.push(10)    li.push(30)    li.push(11)    li.push(21)    li.push(14)    x =21    # Function call    ifli.search(li.head, x):        print("Yes")    else:        print("No")# This code is contributed# by Manoj Sharma | 
C#
| // Recursive C# program to search// an element in linked listusingSystem;// Node classpublicclassNode {    publicintdata;    publicNode next;    publicNode(intd)    {        data = d;        next = null;    }}// Linked list classpublicclassLinkedList {    Node head; // Head of list    // Inserts a new node at the front of the list    publicvoidpush(intnew_data)    {        // Allocate new node and putting data        Node new_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value x is present    // in linked list    publicboolsearch(Node head, intx)    {        // Base case        if(head == null)            returnfalse;        // If key is present in current node,        // return true        if(head.data == x)            returntrue;        // Recur for remaining list        returnsearch(head.next, x);    }    // Driver code    publicstaticvoidMain()    {        // Start with the empty list        LinkedList llist = newLinkedList();        /* Use push() to construct below list        14->21->11->30->10 */        llist.push(10);        llist.push(30);        llist.push(11);        llist.push(21);        llist.push(14);        intx = 21;        // Function call        if(llist.search(llist.head, x))            Console.WriteLine("Yes");        else            Console.WriteLine("No");    }}// This code is contributed by PrinciRaj1992 | 
Javascript
| // Recursive javascript program to search an element// in linked list// Node class class Node {        constructor(val) {            this.data = val;            this.next = null;        }    } // Linked list classvarhead; // Head of list    // Inserts a new node at the front of the list     functionpush(new_data) {        // Allocate new node and putting datavarnew_node = newNode(new_data);        // Make next of new node as head        new_node.next = head;        // Move the head to point to new Node        head = new_node;    }    // Checks whether the value x is present    // in linked list     functionsearch(head , x) {        // Base case        if(head == null)            returnfalse;        // If key is present in current node,        // return true        if(head.data == x)            returntrue;        // Recur for remaining list        returnsearch(head.next, x);    }    // Driver function to test the above functions            // Start with the empty list                /*         * Use push() to construct below list 14->21->11->30->10         */        push(10);        push(30);        push(11);        push(21);        push(14);        varx = 21;        if(search(head, 21))            document.write("Yes");        else            document.write("No");// This code contributed by gauravrajput1 | 
Yes
Time Complexity: O(N)
Auxiliary Space: O(N), Stack space used by recursive calls
This article is contributed by Ravi. Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!


 
                                    







