LeetCode Range Sum Query - Immutable
2015-11-11 22:48
393 查看
Given an integer array nums, find the sum of the elements between indices i and j (i ≤ j), inclusive.
Example:
Note:
You may assume that the array does not change.
There are many calls to sumRange function.
看似简单,但直接在函数内直接求和会超时,题目提示数组是变的,所以我们可以做预处理,然后再求和函数中直接得出结果。题目是求和查询也有直接查出求和结果的意思。
Example:
Given nums = [-2, 0, 3, -5, 2, -1] sumRange(0, 2) -> 1 sumRange(2, 5) -> -1 sumRange(0, 5) -> -3
Note:
You may assume that the array does not change.
There are many calls to sumRange function.
看似简单,但直接在函数内直接求和会超时,题目提示数组是变的,所以我们可以做预处理,然后再求和函数中直接得出结果。题目是求和查询也有直接查出求和结果的意思。
class NumArray { public: NumArray(vector<int> &nums) { num.clear(); if(nums.size() != 0){ num.push_back(nums[0]); for(int i = 1; i < nums.size(); i++) num.push_back(num[i-1]+nums[i]); } } int sumRange(int i, int j) { if(i <= 0) return num[j]; return num[j]-num[i-1]; } private: vector<int> num; }; // Your NumArray object will be instantiated and called as such: // NumArray numArray(nums); // numArray.sumRange(0, 1); // numArray.sumRange(1, 2);
相关文章推荐
- IOS UIProgressView
- 系统自带的UIBarButtonSystemItem样式
- Spark RDD中Transformation的mapValues、subtract、sample、takeSample详解
- ps2015安装guideguide参考线辅助工具
- apue《UNIX环境高级编程第三版》第二章答案详解
- Leetcode153: Permutation Sequence
- NGUI ScrollView让Item居中显示.
- UI第二天:第⼆讲:基础视图、程序启动流程
- solr facet查询及solrj 读取facet数据【facet.prefix应用:搜索引擎拼写提示(也可用suggest);Solr 默认 requestHandler已包含 Facet 组件】
- EASYUI 树形菜单 fastjson JAVA嵌套对象转JSON
- requests的content与text导致lxml的解析问题
- request.getSession()和request.getSession(true/false)的理解
- muduo库阅读(33)——Net部分:定时器队列TimerQueue
- UITableViewEdit
- UITableView的一些方法
- 实现UIScrollView循环滚动
- iOS学习笔记--如何为UITextView设置placeholder
- SoapUI启动报错:The JVM could not be started. The maximum heap size (-Xmx) might be too large
- UIbottun使用详解
- KVC中setValuesForKeysWithDictionary:(写的不错)