█████████ ████ ███░░░░░███ ░░███ ███ ░░░ ██████ ███████ ██████ ██████ ░███ ███░░███ ███░░███ ███░░███ ███░░███ ░███ ░███ ░███░███ ░███ ░███████ ░███ ░███ ░░███ ███░███ ░███░███ ░███ ░███░░░ ░███ ░███ ░░█████████ ░░██████ ░░████████░░██████ ░░██████ ░░░░░░░░░ ░░░░░░ ░░░░░░░░ ░░░░░░ ░░░░░░

Envío 2859

Problema 0x25 - Suma de un subarreglo grande

  • Autor: pradomaricon
  • Fecha: 2021-02-07 05:06:25 UTC (Hace casi 4 años)
Caso # Resultado Tiempo Memoria
#1
Incorrecto
0.133 s 15 KBi
#2
Correcto
0.139 s 15 KBi
#3
Correcto
0.137 s 15 KBi
#4
Correcto
0.141 s 15 KBi
#5
Incorrecto
0.183 s 51 KBi
#6
Incorrecto
0.159 s 16 KBi
#7
Incorrecto
0.171 s 16 KBi
#8
Error en tiempo de ejecución (NZEC)
Exited with error status 137
run: line 1:     3 Killed                  /usr/local/openjdk13/bin/java Main
0.723 s 125 KBi
#9
Tiempo límite excedido
1.187 s 84 KBi
#10
Tiempo límite excedido
1.014 s 34 KBi
#11
Tiempo límite excedido
1.009 s 84 KBi
#12
Tiempo límite excedido
1.068 s 44 KBi
#13
Tiempo límite excedido
1.067 s 85 KBi
#14
Tiempo límite excedido
1.042 s 82 KBi
Puntos totales: 22 / 100

Código

import java.util.Scanner;

public class Main {
    
    public static Scanner leer = new Scanner(System.in);
    public static void main(String[] args) {

        //input dimensiones
        String dimensiones = leer.nextLine().trim();
        int filas = Integer.parseInt(dimensiones);
       
        int[] ejemplo1 = new int[filas];
        
        
        //input de datos
        
            String[] filaDada = leer.nextLine().trim().split(" ");
            int k = 0;
            for (int j = 0; j < filas; j++) {
                ejemplo1[j] = Integer.parseInt(filaDada[k]);
                k++;
                //System.out.println(ejemplo1[i][j]);
            }
            
        //crear matriz con suma acumulada
        int[] matrizAcumulada = new int[filas];
        for (int i = 0; i < filas; i++) {
            if(i==0){
                matrizAcumulada[i]=ejemplo1[i];
            }else{
                matrizAcumulada[i]=matrizAcumulada[i-1]+ejemplo1[i]; 
            }
            
        }
            
        

        //imput consultas
        String numc = leer.nextLine().trim();
        int numConsultas=Integer.parseInt(numc);
        
        for (int i = 0; i < numConsultas; i++) {
            String[] cons = leer.nextLine().trim().split(" ");
            int comienzo=Integer.parseInt(cons[0]);
            int finaliza=Integer.parseInt(cons[1]);
            
            int result=sumaSubarreglo(ejemplo1,filas,comienzo, finaliza);
            
            System.out.println(result);
            
        }
 
    }
    
    
    public static int sumaSubarreglo(int[] matrizAcumulada, int filas, int comienzo, int finaliza){
        int toret=0;
        if(comienzo==0){
            toret=matrizAcumulada[finaliza];
        }else{
            toret=matrizAcumulada[finaliza]-matrizAcumulada[comienzo-1];
        }
        return toret;
}
}