2017-04-27 16 views
0

これは私のコードです: import java.io.IOException; import java.util.Scanner;分割してJAVAベクトルを征服

public class Main { 
    static int operaciones; 
    public static int GetFrequency(int A[],int valor, int izq, int der){ 
     int cont = 0; 
     for(int i=izq; i<= der; i++){ 
      if(A[i] == valor){ 
       cont++; 
      } 
      operaciones++; 
     } 
     return cont; 
    } 
    public static void print(int A[]){ 
     System.out.println("El vector Ingresado Fue: "); 
     System.out.println("--------------------------"); 
     for(int i=1; i<A.length;i++){ 
      System.out.print(A[i] + "\n"); 
     } 
    } 
    public static void ingresar(int A[], int elementos, Scanner sc){ 
     System.out.println("Ingrese los elementos"); 
     for(int i=1; i<A.length;i++){ 
      elementos = sc.nextInt(); 
      A[i]=elementos; 
     } 
    } 
    public static boolean mayoritario(int A[],int i, int j){ 
     if(i<=j){ 
      int valor = 0; 
      for(int x = i; i <j; x++){ 
      valor = GetFrequency(A, A[x], i, j); 
      operaciones++; 
      } 
      if(((A.length-1)%2) == 0){ 
       if(valor > (A.length-1)/2){ 
        return true; 
       } 
      }else{ 
       if(valor >= (A.length/2)){ 
        return true; 
       } 
      } 
      return false; 
     } 
     if(mayoritario(A,i,j/2)){ 
      return true; 
     }if(mayoritario(A,((i+(j/2))),j)){ 

      return true; 
     } 
     return false; 

    } 
    public static void main(String[] args) throws IOException { 
     Scanner sc = new Scanner(System.in); 
     System.out.println("Ingrese cantidad de elementos"); 
     int n = sc.nextInt(); 
     int A [] = new int [n+1]; 
     int elementos = 0; 
     int maximo = n; 
     int minimo = 1; 
     ingresar(A,elementos,sc); 
     print(A); 
     System.out.println("-------------------------"); 
     if(mayoritario(A,minimo,maximo)){ 
      System.out.println("Existe un mayoritario"); 
     }else{ 
      System.out.println("No existe un mayoritario"); 
     } 
     System.out.println("Operaciones = "+operaciones); 

    } 

} 

Iはgetfrequencyと分割統治最も繰り返しNUMを見つける必要があるが、私はT(N)= N^2を有し、これは、T(N)= nlog(n)になるはず。 私は私のソリューションをマージする必要があると思うが、私はこれを行う方法を知らない。なにか提案を ?

答えて

0

各繰り返しでGetFrequencyを実行する代わりに、問題を2つの手順に分けてください。ステップ1で、あなたの頻度を地図に集計します。あなたはO(n)でこれを行うことができるはずです。ステップ2で、Mapを繰り返し、最大値に関連付けられたキーを見つけます。

関連する問題