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

907. 子数组的最小值之和 --力扣 --JAVA

题目

给定一个整数数组 arr,找到 min(b) 的总和,其中 b 的范围为 arr 的每个(连续)子数组。

由于答案可能很大,因此 返回答案模 10^9 + 7 。

解题思路

  1. 找到以当前值为最小值所能组成的子数组;
  2. 若存在两个相同元素则左右边界只允许包含一边,否则会重复计算中间区域;
  3. 在每次计算后对10^9 + 7取余。

代码展示

class Solution {public int sumSubarrayMins(int[] arr) {int MOD = 1000000007;int n = arr.length;long ans = 0L;for (int i = 0; i < n; i++){int num = arr[i];//左右两侧只允许一侧可以等于当前值,否则会重复计算中间值//遍历左侧int left = i - 1;for ( ; left >= 0; left--){if(arr[left] <= num){break;}}//遍历右侧int right = i + 1;for ( ; right < n; right++){if(arr[right] < num){break;}}ans = (ans + (long)(i - left) * (long)(right - i) * num) % MOD;}return (int) ans;}
}

http://www.lryc.cn/news/248958.html

相关文章:

  • 3D模型渲染导致电脑太卡怎么办?
  • 构建个人代理池:使用GitHub项目proxy_pool的搭建配置及代码接口详解
  • Pytorch进阶教学——训练一个图像分类模型(GPU)
  • Docker Swarm总结+CI/CD Devops、gitlab、sonarqube以及harbor的安装集成配置(3/5)
  • Linux:windows 和 Linux 之间文本格式转换
  • VBA技术资料MF88:测试Excel文件名是否有效
  • u8g2图形库——丝滑菜单制作
  • Go 异常处理流程
  • ubuntu20.04安装tensorRT流程梳理
  • 数字孪生技术:提升UI交互性与个性化设计
  • 外包干了5个月,技术退步明显.......
  • 嵌入式常见的几种接口
  • 基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(七)
  • Grafana采用Nginx反向代理,部分功能报错‘Origin not allowed’ behind proxy
  • 请大数据把奥威BI分析工具推给每一个财务!
  • 知乎禁止转载的回答怎么复制做笔记?
  • pta找鞍点—C语言
  • 编程零基础算法 | 四、循环和选择结构——1572. 矩阵对角线元素的和
  • ubantu配置网卡ip
  • 增加F110 付款方式的乱记录
  • 软件系统安全漏洞检测应该怎么做?靠谱的软件安全检测公司推荐
  • 单片机学习12——电容
  • 淘宝平台商品详情平台订单接入说明
  • Linux文件截断命令(truncate head tail dd)
  • Armbian安装python环境和pip国内源
  • 宿主Linux——KVM安装Windows7系统
  • Mysql更新Blob存储的Josn数据
  • C语言——指针(三)
  • VIR-SLAM代码分析3——VIR_VINS详解之estimator.cpp/.h
  • 大模型的RPA应用 | 代理流程自动化(APA),开启智能自动化新纪元