力扣1590.使数组和能被P整除

力扣1590.使数组和能被P整除

  • 同余

    • 转化为求一段区间和余p为x
    • i - j = x
      • j = i - x
cpp 复制代码
  class Solution {
  public:
      int minSubarray(vector<int>& nums, int p) {
          int x = accumulate(nums.begin(),nums.end(),0LL) % p;
          if(x == 0) return 0;
          int n = nums.size(),ans = n,s = 0;
          unordered_map<int,int> last{{s,-1}};
          for(int i=0;i<n;i++)
          {
              s = (s + nums[i]) % p;
              last[s] = i;
              auto it = last.find((s - x + p) % p);
              if(it != last.end())
                  ans = min(ans,i - it->second);
          }
          return ans < n ? ans : -1;
      }
  };
相关推荐
风中的微尘13 小时前
39.网络流入门
开发语言·网络·c++·算法
西红柿维生素13 小时前
JVM相关总结
java·jvm·算法
ChillJavaGuy15 小时前
常见限流算法详解与对比
java·算法·限流算法
散11215 小时前
01数据结构-01背包问题
数据结构
sali-tec15 小时前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#
消失的旧时光-194316 小时前
Kotlinx.serialization 使用讲解
android·数据结构·android jetpack
Gu_shiwww16 小时前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
你怎么知道我是队长17 小时前
C语言---循环结构
c语言·开发语言·算法
艾醒17 小时前
大模型面试题剖析:RAG中的文本分割策略
人工智能·算法
苏小瀚17 小时前
[数据结构] 排序
数据结构