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

​力扣解法汇总1590. 使数组和能被 P 整除

 目录链接:

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

GitHub同步刷题项目:

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

原题链接:力扣


描述:

给你一个正整数数组 nums,请你移除 最短 子数组(可以为 ),使得剩余元素的  能被 p 整除。 不允许 将整个数组都移除。

请你返回你需要移除的最短子数组的长度,如果无法满足题目要求,返回 -1 。

子数组 定义为原数组中连续的一组元素。

示例 1:

输入:nums = [3,1,4,2], p = 6
输出:1
解释:nums 中元素和为 10,不能被 p 整除。我们可以移除子数组 [4] ,剩余元素的和为 6 。

示例 2:

输入:nums = [6,3,5,2], p = 9
输出:2
解释:我们无法移除任何一个元素使得和被 9 整除,最优方案是移除子数组 [5,2] ,剩余元素为 [6,3],和为 9 。

示例 3:

输入:nums = [1,2,3], p = 3
输出:0
解释:和恰好为 6 ,已经能被 3 整除了。所以我们不需要移除任何元素。

示例  4:

输入:nums = [1,2,3], p = 7
输出:-1
解释:没有任何方案使得移除子数组后剩余元素的和被 7 整除。

示例 5:

输入:nums = [1000000000,1000000000,1000000000], p = 3
输出:0

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 109
  • 1 <= p <= 109

解题思路:

* 解题思路:
* 我的解法还是比较差的一种,时间复杂度达到了O(n2)。
* 首先求出diff值,为总和和p的余数,
* 然后使用前缀和,分别求长度为1,2,3,4的子数组,
* 求子数组的值,看是否有满足diff == (i1 % p)的

代码:

public class Solution1590 {public int minSubarray(int[] nums, int p) {int length = nums.length;long[] prifixSum = new long[length + 1];prifixSum[0] = 0;for (int i = 0; i < nums.length; i++) {int value = nums[i];prifixSum[i + 1] = prifixSum[i] + value;}if (p > prifixSum[length]) {return -1;}if (prifixSum[length] % p == 0) {return 0;}long diff = prifixSum[length] % p;for (int i = 1; i < length; i++) {for (int index = i; index <= length; index++) {long i1 = prifixSum[index] - prifixSum[index - i];if (diff == (i1 % p)) {return i;}}}return -1;}
}

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

相关文章:

  • Spring源码阅读(基础)
  • 服务搭建篇(九) 使用GitLab+Jenkins搭建CI\CD执行环境 (上) 基础环境搭建
  • CDC 长沙站丨云原生技术研讨会:数字兴链,云化未来!
  • A.特定领域知识图谱知识推理方案:知识图谱推理算法综述[二](DTransE/PairRE:基于表示学习的知识图谱链接预测算法)
  • 香港酒店模拟分析项目报告--使用tableau、python、matlab
  • 第18天-商城业务(商品检索服务,基于Elastic Search完成商品检索)
  • 5.2 对射式红外传感器旋转编码器计次
  • 【数据库概论】第九章 关系查询处理和查询优化
  • (WIP) my cloud test bed (by quqi99)
  • git | git 2023 详细版
  • camunda流程引擎基本使用(笔记)
  • JS之数据结构与算法
  • CnOpenData·A股上市企业数字化转型指数数据
  • VMware16pro虚拟机安装全过程
  • 阿里云第六代云服务器最新价格表(计算型c6、通用型g6和内存型r6)
  • 微小目标识别研究(2)——基于K近邻的白酒杂质检测算法实现
  • 2022-06-14至2022-08-11 关于复现MKP算法的总结与反思
  • IBMMQ教程二(window版安装)
  • Java | HashSet 语法
  • js学习4(运算符)
  • 2月更新 | Visual Studio Code Python
  • C++回顾(十八)—— 文件操作
  • 以java编写员工管理系统(测试过 无问题)
  • 单例模式之懒汉式
  • 1638_chdir函数的功能
  • 使用CEF 获得某头条请求,并生成本地文件的方法
  • 二十、Django-restframework之视图集和路由器
  • [深入理解SSD系列 闪存实战2.1.2] SLC、MLC、TLC、QLC、PLC NAND_固态硬盘闪存颗粒类型
  • 论文阅读-MGTAB: A Multi-Relational Graph-Based Twitter Account DetectionBenchmark
  • 基于libco的c++协程实现(时间轮定时器)