Clean Java Solution using TreeMap

  • -4
    public class Solution {
        public int countRangeSum(int[] nums, int lower, int upper) {
            int count = 0;
            long[] sum = new long[nums.length+1];
            TreeMap<Long, Integer> map = new TreeMap<Long, Integer>(); 
            map.put(0L, 1);
            for(int i=0; i<nums.length; i++){
                sum[i+1] = sum[i]+nums[i];
                map.put(sum[i+1], map.containsKey(sum[i+1])? map.get(sum[i+1])+1: 1);
            for(int i=0; i<nums.length; i++){
                map.put(sum[i], map.get(sum[i])-1);
                if(map.get(sum[i]) == 0) map.remove(sum[i]);
                for(Map.Entry<Long, Integer> entry: map.subMap(sum[i]+lower, sum[i]+upper+1).entrySet())
                    count += entry.getValue();
            return count;

  • 0

    This is very similar to my first solution, but unfortunately it's worst case O(n^2). Consider the case when most sums are different and yet within the given range. That inner loop will have about n iterations on each outer loop iteration.

Log in to reply

Looks like your connection to LeetCode Discuss was lost, please wait while we try to reconnect.