Well I fixed my algorithm and managed to solve the problem (see previous post). Here is a general overview.
- Create array of cumulative sums
- Create Segment tree
- Answer queries using segment tree
Now I'm moving onto GSS3, which is more or less the same problem but with the ability to update sequence elements in addition to making queries. At the moment I plan to use the same code but modify certain parts so they they use binary indexed trees.
Found this to be a pretty interesting problem. Think I might try to implement a version for working with 2D arrays. Really it's not too hard to extend to more dimensions but the code just gets longer though the thought process stays the same. To me this is probably the major advantage of using segment trees over sparse arrays. But I must admit that I am not all that comfortable with the sparse array method, so it might extend just as easily (though I don't see it).
2 comments:
Interesting. I think I used a binary indexed tree also (for both 1 and 3), though I'm not 100% sure as TC tutorials tend to confuse more than enlighten.
I tried using a Binary Indexed Tree for 3 but it was too slow. Maybe there is some trick with that method that I'm just not seeing.
Post a Comment