首页 > 其他 > 详细

Lintcode: Interval Sum

时间:2016-02-02 06:25:32      阅读:214      评论:0      收藏:0      [点我收藏+]
Given an integer array (index from 0 to n-1, where n is the size of this array), and an query list. Each query has two integers [start, end]. For each query, calculate the sum number between index start and end in the given array, return the result list.

Have you met this question in a real interview? Yes
Example
For array [1,2,7,8,5], and queries [(0,4),(1,2),(2,4)], return [23,9,20]

Note
We suggest you finish problem Segment Tree Build, Segment Tree Query and Segment Tree Modify first.

Challenge
O(logN) time for each query

这道题最简便的方法当然是prefix Sum

/**
 * Definition of Interval:
 * public classs Interval {
 *     int start, end;
 *     Interval(int start, int end) {
 *         this.start = start;
 *         this.end = end;
 *     }
 */
public class Solution {
    /**
     *@param A, queries: Given an integer array and an query list
     *@return: The result list
     */
    public ArrayList<Long> intervalSum(int[] A, 
                                       ArrayList<Interval> queries) {
        // write your code here
        long[] prefixSum = new long[A.length+1];
        for (int i=0; i<A.length; i++) {
            prefixSum[i+1] = prefixSum[i] + A[i];
        }
        ArrayList<Long> res = new ArrayList<Long>();
        for (Interval interval : queries) {
            int start = interval.start;
            int end = interval.end;
            long result = prefixSum[end+1] - prefixSum[start];
            res.add(result);
        }
        return res;
    }
}

用Segment Tree

 1 /**
 2  * Definition of Interval:
 3  * public classs Interval {
 4  *     int start, end;
 5  *     Interval(int start, int end) {
 6  *         this.start = start;
 7  *         this.end = end;
 8  *     }
 9  */
10 public class Solution {
11     /**
12      *@param A, queries: Given an integer array and an query list
13      *@return: The result list
14      */
15     public class SegmentTreeNode {
16         long sum;
17         int start;
18         int end;
19         SegmentTreeNode left;
20         SegmentTreeNode right;
21         public SegmentTreeNode(int start, int end) {
22             this.sum = 0;
23             this.start = start;
24             this.end = end;
25             this.left = null;
26             this.right = null;
27         }
28     }
29      
30     SegmentTreeNode root;
31      
32     public ArrayList<Long> intervalSum(int[] A, 
33                                        ArrayList<Interval> queries) {
34         // write your code here
35         ArrayList<Long> res = new ArrayList<Long>();
36         root = build(A, 0, A.length-1);
37         for (Interval interval : queries) {
38             int start = interval.start;
39             int end = interval.end;
40             res.add(query(root, start, end));
41         }
42         return res;
43     }
44     
45     public SegmentTreeNode build(int[] A, int start, int end) {
46         SegmentTreeNode cur = new SegmentTreeNode(start, end);
47         if (start == end) {
48             cur.sum = A[start];
49         }
50         else {
51             int mid = (start + end)/2;
52             cur.left = build(A, start, mid);
53             cur.right = build(A, mid+1, end);
54             cur.sum = cur.left.sum + cur.right.sum;
55         }
56         return cur;
57     }
58     
59     public Long query(SegmentTreeNode cur, int start, int end) {
60         if (cur.start==start && cur.end==end) return cur.sum;
61         int mid = (cur.start + cur.end)/2;
62         if (end <= mid) return query(cur.left, start, end);
63         else if (start > mid) return query(cur.right, start, end);
64         else return query(cur.left, start, mid) + query(cur.right, mid+1, end);
65     }
66 }

 

Lintcode: Interval Sum

原文:http://www.cnblogs.com/EdwardLiu/p/5176673.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!