摘要:很簡單的題目,不過要達(dá)到的時(shí)間,只能用前綴和的方法來做。法前綴和法推薦
Problem
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.
ExampleFor array [1,2,7,8,5], and queries [(0,4),(1,2),(2,4)], return [23,9,20]
ChallengeO(logN) time for each query
Note很簡單的題目,不過要達(dá)到O(logn)的時(shí)間,只能用前綴和的方法來做。
Solution1. muggle法
public class Solution { public ArrayListintervalSum(int[] A, ArrayList queries) { ArrayList res = new ArrayList (); for (int i = 0; i < queries.size(); i++) { int start = queries.get(i).start; int end = queries.get(i).end; res.add(sum(A, start, end)); } return res; } public long sum(int[] A, int start, int end) { long sum = 0; for (int i = start; i <= end; i++) { sum += A[i]; } return sum; } }
2. 前綴和法(推薦)
public class Solution { public ArrayListintervalSum(int[] A, ArrayList queries) { ArrayList res = new ArrayList (); long[] preSum = new long[A.length]; long sum = 0; for (int i = 0; i < A.length; i++) { sum += A[i]; preSum[i] = sum; } for (Interval i: queries) { if (i.start == 0) { res.add(preSum[i.end]); } else { res.add(preSum[i.end] - preSum[i.start-1]); } } return res; } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66196.html
摘要:方法上沒太多難點(diǎn),先按所有區(qū)間的起點(diǎn)排序,然后用和兩個(gè)指針,如果有交集進(jìn)行操作,否則向后移動。由于要求的,就對原數(shù)組直接進(jìn)行操作了。時(shí)間復(fù)雜度是的時(shí)間。 Problem Given a collection of intervals, merge all overlapping intervals. Example Given intervals => merged intervals...
摘要:這道題目是篩選出數(shù)組中的最小值,存入新數(shù)組。因此,聯(lián)想到和系列的題目,對于的處理,使用線段樹是非常有效的方法。之前我們創(chuàng)建的線段樹,有和兩個(gè)。參照這個(gè)參數(shù),可以考慮在這道題增加一個(gè)的參數(shù),代表每個(gè)結(jié)點(diǎn)的最小值。 Problem Given an integer array (index from 0 to n-1, where n is the size of this array),...
Problem Given an array of meeting time intervals consisting of start and end times [[s1,e1],[s2,e2],...] (si < ei), determine if a person could attend all meetings. Example Given intervals = [[0,30],[...
摘要:題目是要查詢到這個(gè)區(qū)間內(nèi)某一點(diǎn)的。值是從最底層的子節(jié)點(diǎn)值里取最大值。因此,不用太復(fù)雜,遞歸就可以了。與所不同的是,對所給區(qū)間內(nèi)的元素個(gè)數(shù)求和,而非篩選。這樣就會出現(xiàn)的情況,視作本身處理。 Segment Tree Query Problem For an integer array (index from 0 to n-1, where n is the size of this ar...
Problem In LOL world, there is a hero called Teemo and his attacking can make his enemy Ashe be in poisoned condition. Now, given the Teemos attacking ascending time series towards Ashe and the poison...
閱讀 943·2021-09-07 09:58
閱讀 1494·2021-09-07 09:58
閱讀 2888·2021-09-04 16:40
閱讀 2508·2019-08-30 15:55
閱讀 2416·2019-08-30 15:54
閱讀 1374·2019-08-30 15:52
閱讀 438·2019-08-30 10:49
閱讀 2610·2019-08-29 13:21