Find Second Largest Number From Array | Java Interview Questions and Answers

Поделиться
HTML-код
  • Опубликовано: 10 дек 2024

Комментарии • 45

  • @developer00007
    @developer00007 2 года назад +7

    Answer: Yes it will definitely work.
    I have few approaches to solve this problem:
    Approach 1:
    Step 1: Add all the elements in a Set.
    Step 2: Now add all elements from set into a new ArrayList and Sort.
    Step 3 : Get size -2 th element
    Time Complexity O(nlogn)
    Space Complexity O(n)
    Approach 2: (Using Heap or PriorityQueue)
    Step 1: Add All elements into a set to remove duplicates
    Step 2: Iterate through each elements of the set and add it into the Min Heap.
    Step 3: Check if the size of Heap >2 then pop the top elements.
    Step 4: Return Top element
    Time Complexity: O(nlog2)
    Space Complexity:O(n)
    If there were no Duplicates then Space Complexity can Be constant.

  • @sandeshkulkarni6941
    @sandeshkulkarni6941 2 года назад +3

    I think first we have to remove duplicate elements from array and then we sort,
    After that there no problem if we give any updated array

  • @stayvloging
    @stayvloging 2 года назад +21

    public class SecondLargestNumberFromTheArray {
    public static void main(String[] args) {
    int arr[] = { 1, 4, 35, 34, 35, 35 };
    int largest = arr[0];
    int secondLargest = arr[0];
    for (int i = 0; i < arr.length; i++) {
    if (largest < arr[i]) {
    secondLargest = largest;
    largest = arr[i];
    } else if (secondLargest < arr[i] && largest > arr[i]) {
    secondLargest = arr[i];
    }
    }
    System.out.println(secondLargest);
    }
    }

    • @trendinguniverse6113
      @trendinguniverse6113 2 года назад

      I am thinking about same but it will work if there are duplicate elements in array like that in pprogram

    • @stayvloging
      @stayvloging 2 года назад

      @@trendinguniverse6113 yes it will work

    • @sravan77751
      @sravan77751 Год назад +1

      if the first element is largest it will not work { 35, 4, 1, 34, 35, 35 };

    • @harikishangrandhe3381
      @harikishangrandhe3381 11 месяцев назад

      @@sravan77751I guess it will work

  • @unknownplayer0383
    @unknownplayer0383 2 года назад

    program will continue to work as expected. thank you for the video

  • @sathiskumarp
    @sathiskumarp 2 года назад

    It will work as expected, since we are checking the highest number logic!!!

  • @bheemshankar_pk
    @bheemshankar_pk 7 месяцев назад +1

    Good Logic Thanks,what if there are null values in array ,then how to find 2nd largest??

  • @omkar_gopchade143
    @omkar_gopchade143 2 года назад +1

    I think it will definitely work

  • @dreamplaying-wg1jn
    @dreamplaying-wg1jn 2 года назад +2

    Yes bro it will work

    • @stayvloging
      @stayvloging 2 года назад

      public class SecondLargestNumberFromTheArray {
      public static void main(String[] args) {
      int arr[] = { 1, 4, 35, 34, 35, 35 };
      int largest = arr[0];
      int secondLargest = arr[0];
      for (int i = 0; i < arr.length; i++) {
      if (largest < arr[i]) {
      secondLargest = largest;
      largest = arr[i];
      } else if (secondLargest < arr[i] && largest > arr[i]) {
      secondLargest = arr[i];
      }
      }
      System.out.println(secondLargest);
      }
      }

  • @newanurag
    @newanurag 2 года назад +1

    Just using the builtin functions.
    where is the brain applied?

  • @bhargavmehta97
    @bhargavmehta97 Год назад +1

    What about array of negative numbers?

  • @akhilraj5268
    @akhilraj5268 2 года назад +6

    I don't think last code is suitable for all testcases

    • @cloudtech5260
      @cloudtech5260  2 года назад +1

      Any idea on what test case moght not pass.

    • @dipalialone1298
      @dipalialone1298 2 года назад +1

      When all elements are same then it will fail

    • @developer00007
      @developer00007 2 года назад +1

      @@dipalialone1298They Have Handle it. Watch again

  • @SaravanaKumar-lx8ue
    @SaravanaKumar-lx8ue 19 дней назад

    int max = 0;
    int smax = 0;
    if(arr.length < 2)
    return -1;
    for(int i = 0; i max){
    smax = max;
    max = arr[i];
    } else if ((arr[i]>smax) && (arr[i]!=max)) {
    smax = arr[i];
    }
    }
    if(smax == 0)
    return -1;
    return smax;
    smax will hold the value of second largest, this code has only one iteration of the array. Complexity is O(n).

  • @rmcf3972
    @rmcf3972 7 месяцев назад +1

    Will this work in an array of 100,000 integers?

  • @manukarthikeya4560
    @manukarthikeya4560 7 месяцев назад

    Is this code from gfg ??

  • @siddumaradi7045
    @siddumaradi7045 2 года назад

    yes it'll work sir

  • @princemohammed921
    @princemohammed921 Год назад +1

    For bigger test cases it is not working

  • @jeckrazi7691
    @jeckrazi7691 Год назад +1

    Hi @CloudTech,
    Stream.of(1,4,5,35,34,35)
    .sorted((n1,n2)-> Integer.compare(n2,n1))
    .distinct()
    .limit(2)
    .skip(1)
    .forEach(System.out::println);

  • @darknight66655
    @darknight66655 3 месяца назад

    yes it will work surr**

  • @nitheeshreddy6863
    @nitheeshreddy6863 2 года назад +2

    hi bro i have used this logic can u please check this..
    int array[]=new int [] {1,4,5,35,35,35,34};
    Arrays.sort(array); //1,2,4,34,35,35;
    int highest=array[array.length-1];
    for(int i=array.length-2;i>=0;i--) {
    if(highest>array[i]) {
    System.out.println(array[i]);
    break;
    }
    }

  • @trendinguniverse6113
    @trendinguniverse6113 2 года назад +1

    Bro pls make remove duplicate elements from array

    • @girijasankardas1189
      @girijasankardas1189 2 года назад +1

      you can easily remove duplicate element by using HashSet brother.

  • @coolraviraj24
    @coolraviraj24 2 года назад

    yes it will

  • @gautamnegi6868
    @gautamnegi6868 2 года назад

    Yes

  • @chaitanaywaskar6008
    @chaitanaywaskar6008 Год назад

    at some cases of gfg , this code don't work .

  • @Jaanufufjf
    @Jaanufufjf 8 месяцев назад

    If I add second largest element two time
    Then this logic will give error

  • @ChennaiCineCuts
    @ChennaiCineCuts 2 года назад

    Better to make it as Hashset to remove duplicates

  • @shaikhkhizar3167
    @shaikhkhizar3167 2 года назад

    This logic won't work, if we take the array elements as a input from user.

    • @hariprasadmutalikdesai6504
      @hariprasadmutalikdesai6504 2 года назад +1

      But code working with user input with me. and code is
      import java.util.Arrays;
      import java.util.Scanner;
      public class MainClass {
      public static void main(String[] args) {
      printsecondlargest();
      }

      public static void printsecondlargest() {
      int n;
      Scanner sc = new Scanner(System.in);
      System.out.println("Enter the No of Elements to store in array : ");
      n = sc.nextInt();
      int[] array = new int[n];
      System.out.println("Enter the array Elements : ");
      for (int i=0; i 0; i--) {
      if(array[i] != array[size-1]) {
      System.out.println("Second Largest Element is "+array[i]);
      return;
      }
      }
      System.out.println("No such Element Present");
      }
      }
      Output:
      Enter the No of Elements to store in array :
      6
      Enter the array Elements :
      13
      35
      35
      23
      34
      13
      Second Largest Element is 34

  • @bhushantaywadevlogs9552
    @bhushantaywadevlogs9552 Год назад +1

    Very bad logic...

  • @yogeshganpule2695
    @yogeshganpule2695 Год назад

    This will fail in case you have 2 duplicate elements as smallest . for ex int[] arr = {1, 2, 5, 7, 8, 9, -14, 56, 98, -3, -14, 2};