Q2. Max number
Given an array A of size N (at least three), you need to find its first, second and third maximum elements
Input
The first line of the input contains the number of test cases T.
For each test case, the first line of the input contains an integer N denoting the number of elements in the array A. The next line contains N (space separated) elements of A.
Constraints:
1 <= T <= 100
3 <= N <= 10^6
1 <= A[i] <= 10^9
Note:-It is guaranteed that the sum of N over all text cases does not exceed 10^6
For each test case, the first line of the input contains an integer N denoting the number of elements in the array A. The next line contains N (space separated) elements of A.
Constraints:
1 <= T <= 100
3 <= N <= 10^6
1 <= A[i] <= 10^9
Note:-It is guaranteed that the sum of N over all text cases does not exceed 10^6
Output
For each test case, output the first, second and third maximum elements in the array.
Example
Sample Input:
3
5
1 4 2 4 5
6
1 3 5 7 9 8
7
11 22 33 44 55 66 77
Sample Output:
5 4 4
9 8 7
77 66 55
Explanation(might now be the optimal solution):
Testcase 1:
[1 4 2 4 5]
First max = 5
Second max = 4
Third max = 4
import java.io.*; // for handling input/output
import java.util.*; // contains Collections framework
// don't change the name of this class
// you can add inner classes if needed
class Main {
public static void main (String[] args) {
Scanner in = new Scanner(System.in);
int t = in.nextInt();
for (int i = 1; i <= t; i++) {
int n = in.nextInt();
int arr[] = new int[n];
for (int j = 0; j < n; j++) {
arr[j] = in.nextInt();
}
int first = 0;
int second = 0;
int third = 0;
for (int k = 0; k < n; k++) {
if (arr[k] > first) {
third = second;
second = first;
first = arr[k];
} else if (arr[k] > second) {
third = second;
second = arr[k];
} else if (arr[k] > third)
third = arr[k];
}
System.out.println(first+" "+second+" "+ third);
}}}
Post a Comment