今天介绍的是LeetCode算法题中Easy级别的第70题(顺位题号是303)。给定整数数组nums,找到索引i和j(i≤j)之间的元素之和,包括端点。例如:算法
给定nums = [-2,0,3,-5,2,-1]数组
sumRange(0,2) - > 1数据结构
sumRange(2,5) - > -1eclipse
sumRange(0,5) - > -3函数
注意:工具
您能够假设数组不会更改。开发工具
sumRange函数有不少调用。测试
本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。
spa
使用暴力解法,直接使用for循环依次将i到j之间的元素求和,最后再返回其和。code
此解法空间复杂度是O(1),时间复杂度是O(n)。
class NumArray { public int[] arr; public NumArray(int[] nums) { arr = nums; } public int sumRange(int i, int j) { int sum = 0; for (int k=i; k<= j; k++) { sum += arr[k]; } return sum; } }
若是使用第一种解法,sumRange的方法调用次数太多,而且每次都要从新开始计算,咱们能够事先把不一样位置元素的和算出来存到另一个数组中,在sumRange中直接去新数组中取对应位置的和作减法便可。
此解法时间复杂度是O(1),空间复杂度是O(n)。
class NumArray2 { public int[] sum; public NumArray2(int[] nums) { sum = new int[nums.length+1]; for (int i=0; i<nums.length; i++) { sum[i+1] = nums[i] + sum[i]; } } public int sumRange(int i, int j) { return sum[j+1] - sum[i]; } }
算法专题目前已连续日更超过两个月,算法题文章70+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是所有内容,若是你们有什么好的解法思路、建议或者其余问题,能够下方留言交流,点赞、留言、转发就是对我最大的回报和支持!