当前位置: 首页 > news >正文

化工网站制作/黑龙江网络推广好做吗

化工网站制作,黑龙江网络推广好做吗,手机注册企业邮箱,找第三方做网站 需要注意目录链接: 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目: https://github.com/September26/java-algorithms 原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 描述: 给你一个数…

 目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台


描述:

给你一个数组 nums ,请你完成两类查询。

  1. 其中一类查询要求 更新 数组 nums 下标对应的值
  2. 另一类查询要求返回数组 nums 中索引 left 和索引 right 之间( 包含 )的nums元素的  ,其中 left <= right

实现 NumArray 类:

  • NumArray(int[] nums) 用整数数组 nums 初始化对象
  • void update(int index, int val) 将 nums[index] 的值 更新 为 val
  • int sumRange(int left, int right) 返回数组 nums 中索引 left 和索引 right 之间( 包含 )的nums元素的  (即,nums[left] + nums[left + 1], ..., nums[right]

示例 1:

输入:
["NumArray", "sumRange", "update", "sumRange"]
[[[1, 3, 5]], [0, 2], [1, 2], [0, 2]]
输出:
[null, 9, null, 8]解释:
NumArray numArray = new NumArray([1, 3, 5]);
numArray.sumRange(0, 2); // 返回 1 + 3 + 5 = 9
numArray.update(1, 2);   // nums = [1,2,5]
numArray.sumRange(0, 2); // 返回 1 + 2 + 5 = 8

提示:

  • 1 <= nums.length <= 3 * 104
  • -100 <= nums[i] <= 100
  • 0 <= index < nums.length
  • -100 <= val <= 100
  • 0 <= left <= right < nums.length
  • 调用 update 和 sumRange 方法次数不大于 3 * 104 

解题思路:

这题数组的长度为310^4,如果时间复杂度是O(n2),则会超时。所以这题一定不能每次都遍历。 
但是我们可以发现一个规律,就是update的时候,影响的范围很小,甚至有可能都对sumRange不产生影响,所以,我们可以把影响范围缩减到最小。
我们可以把nums数组划分为k块,暂且用N1,N2,Nk表示,则left和right会出现2种情况。 
left和right属于同一块:这种情况,直接求left和right的累加值即可。 
left和right不属于同一块:这种情况,求left到其所属块的尾之间的和,right所属的块的头到right之间的和,以及left和right之间的块的和。三者相加,就是最终值。

代码:

class NumArray {private int[] nums;private int[] pieces;private int pieceLength;public NumArray(int[] nums) {this.nums = nums;pieceLength = (int) Math.ceil(Math.sqrt(nums.length));pieces = new int[nums.length / pieceLength + 1];for (int i = 0; i < nums.length; i++) {pieces[i / pieceLength] = pieces[i / pieceLength] + nums[i];}}public void update(int index, int val) {pieces[index / pieceLength] += (val-nums[index]);nums[index] = val;}public int sumRange(int left, int right) {int piece1 = left / pieceLength;int piece2 = right / pieceLength;int sum1 = 0, sum2 = 0, sum3 = 0;if (piece1 == piece2) {for (int i = left; i <= right; i++) {sum1 += nums[i];}} else {for (int i = left; i < pieceLength * (piece1+1); i++) {sum1 += nums[i];}for (int i = pieceLength * piece2; i <= right; i++) {sum3 += nums[i];}for (int i = piece1 + 1; i < piece2; i++) {sum2 += pieces[i];}}int sum = sum1 + sum2 + sum3;return sum;}}

http://www.ho-use.cn/article/369.html

相关文章:

  • 品牌设计公司网站/游戏优化
  • 东安网站建设/安年软文网
  • 自己开公司 自己做网站/免费收录网站推广
  • 长沙建设银行招聘网站/网址解析ip地址
  • 东莞市传送机技术支持 网站建设/湖南网站建设推广优化
  • 建设的网站服务器/哪家公司建设网站好
  • 制作网页时要综合考虑哪些因素/哈尔滨seo推广
  • 吴江网站建设/网络推广方案的内容
  • 新能源课件网站开发新能源/如何自建网站?
  • 专业做网站的公司哪家好/app运营
  • 中国空间站即将建成/360应用商店
  • 安徽建设工程信息网怎么打不开了/福建seo优化
  • 怎么看网站是哪个平台做的/站长工具网
  • 我是新手如何做跨境电商/成都官网seo服务
  • 网站突然显示 建设中/提高工作效率
  • 天津河北区做网站/百度权重4网站值多少钱
  • 阿里巴巴网站如何做固定背景/广告关键词
  • h5网站建设/长沙网站开发制作
  • wordpress 站点换域名/如何找友情链接
  • 网站建设的一般步骤/超级外链工具 增加外链中
  • 网站建设的技术阶段/北京百度推广代理公司
  • 旅游网站建设成本核算/哈尔滨最新疫情通报
  • 如何做好企业网站/绍兴seo计费管理
  • 盐城市城乡建设局网站/免费的推广引流软件下载
  • 建设一个网站/销售平台
  • js做网站/搜索引擎收录入口
  • 太钢建设公司官网/宁波seo网络推广代理公司
  • 做网站政府扶持/搜索量排名
  • 却持网站/今日十大热点新闻头条
  • 旅游平台网站建设方案/网店营销的推广方法有哪些