Блог пользователя Aalchemist

Автор Aalchemist, история, 8 лет назад, По-английски

My c++ solution got accepted. But same process for java causing memory limit exceeded error. can any one explain ??? it's a segment tree problem . I am just switching my language from cpp to java. but i am facing problem while submitting in different on line judges. As in this case same code in c++ got accepted.

Any tips to solve problem in java will definitely help me. I am in great danger.

problem link

my code

import java.util.*;

class segmnetTree {

int []  array, segarray;


segmnet()
{
    array=new int[100001];
    segarray=new int[400001];
}
int left(int n)
{
    return 2*n;
}
int right( int n)
{
    return 2*n+1;
}

void brmq(int p, int l, int r)
{
    if(l==r)
    {
        segarray[p]=array[l];
        return;
    }

    brmq(left(p),l,(l+r)/2);
    brmq(right(p),(l+r)/2+1,r);

    segarray[p]=Math.min(segarray[left(p)],segarray[right(p)]);
}

int rmq( int p,int l, int r, int i, int j)
{
    if(i>r || j<l)  return -1; // MAXXXX or set it in a way to understand
    else if(l>=i && r<=j)  return segarray[p];
    int a1=rmq( left(p), l,(l+r)/2, i,j);
    int a2=rmq( right(p), (l+r)/2+1 , r , i,j);

    if(a1==-1) return a2;
    if(a2==-1) return a1;
    else return Math.min(a1,a2);
}

}

public class SegmentTree {

public static void main(String[] args) {

    segmnet s1=new segmnet();
    Scanner sin=new Scanner(System.in);
    int cas=sin.nextInt();
    for( int cno=1; cno<=cas;cno++)
    {
        int n,q;
        n=sin.nextInt();
        q=sin.nextInt();


        for( int m=1;m<=n;m++)
        {
            s1.array[m]=sin.nextInt();
        }
        s1.brmq(1,1,n);
        System.out.println("Case "+cno+":");
        for( int m=0;m<q;m++)
        {
            int i,j;
            i=sin.nextInt();
            j=sin.nextInt();
            System.out.println(s1.rmq(1,1,n,i,j));



        }

    }

}

}

  • Проголосовать: нравится
  • 0
  • Проголосовать: не нравится

»
8 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Scanner tends to be quite slow reading the input (enough for TLE). Try a faster input reader, e.g. check Petr's — http://codeforces.me/contest/700/submission/19337666

  • »
    »
    8 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится

    I didn't get TLE. my memory limit was exceeded. but thanks for your help. :)

    • »
      »
      »
      8 лет назад, # ^ |
        Проголосовать: нравится 0 Проголосовать: не нравится

      I'm sorry, I misread. I'm not seeing a reason for MLE, even stack size overlow seems unlikely.

»
7 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

It's an issue with lightoj. Write this line " System.exit(0); " in the last line of main method. MLE issue will be fixed.

»
7 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

I faced the same problem with segment trees in C# but I changed all long numbers to int .

I don't see the reason to MLE with you .

try another DS .I don't think there will be a solution for this issue here .