Caso # | Resultado | Tiempo | Memoria |
---|---|---|---|
#1 |
Correcto
|
0.083 s | 16 KBi |
#2 |
Incorrecto
|
0.091 s | 17 KBi |
#3 |
Correcto
|
0.079 s | 16 KBi |
#4 |
Correcto
|
0.086 s | 16 KBi |
#5 |
Correcto
|
0.13 s | 18 KBi |
#6 |
Incorrecto
|
0.093 s | 16 KBi |
#7 |
Incorrecto
|
0.099 s | 16 KBi |
#8 |
Incorrecto
|
0.102 s | 17 KBi |
#9 |
Correcto
|
0.103 s | 16 KBi |
#10 |
Correcto
|
0.103 s | 16 KBi |
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int[] a = new int[n]; for(int i=0; i<n; i++){ a[i] = scanner.nextInt(); } Arrays.sort(a); int c = scanner.nextInt(); for(int i=0; i<c; i++){ int consulta = scanner.nextInt(); int index = findSuccesor(a, 0, n-1, consulta); System.out.println(n - index); } } private static int findSuccesor(int[] a, int start, int end, int search) { if(end == start + 1 || end == start){ if(search < a[start] && a[start] < a[end]){ return start; } if(search < a[end]){ return end; } return a.length; } int middle = (end+start)/2; boolean flag = true; if(middle - 1 >= 0){ if(search <= a[middle-1]){ flag = false; } } if(middle + 1 < a.length){ if(a[middle] == a[middle+1]){ flag = false; } } if(search >= a[middle]){ flag= false; } if(flag) { return middle; } if (search<a[middle]){ return findSuccesor(a, start, middle-1, search); } else { return findSuccesor(a, middle+1, end, search); } } }