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

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

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

  • 同余

    • 转化为求一段区间和余p为x
    • i - j = x
      • j = i - x
  •   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;
          }
      };
    

http://www.kler.cn/a/280142.html

相关文章:

  • ViewModel(8)单元测试
  • 华为od(D卷)路口最短时间问题
  • Android12 Toast连续多次点击后不显示
  • 【python】数据分析统计
  • 转-600条最强linux命令
  • js知识补充
  • oracle内存结构--PGA(进程全局区)私有的
  • PPT布局图片文本解析检测系统源码分享 # [一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • 干货满满!五大调光方式让你全面了解LED照明
  • OpenCV绘图函数(7)从一个椭圆定义中提取出多边形的顶点坐标函数ellipse2Poly()的使用
  • 【自动驾驶】控制算法(三)轮胎侧偏与车辆动力学模型
  • 常用的编写VBA的软件 (L*00K)
  • AVL 树的实现与应用
  • (附源码)SSM高校图书馆座位的智能化管理系统小程序-计算机毕设 15796
  • minio 后端大文件分片上传,合并,删除分片
  • PHP Vue学生档案管理系统:如何实现快速信息检索与数据安全?
  • 前端手写源码系列(三)——手写_deepClone深浅拷贝
  • 专利可以用来评职称吗
  • 【云原生系列之SkyWalking的部署】
  • 【ceph学习】ceph如何进行数据的读写(1)