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

【LeetCode每日一题】2381. 字母移位 II2406. 将区间分为最少组数 (差分数组)

差分数组案例

2381. 字母移位 II

给你一个小写英文字母组成的字符串 s 和一个二维整数数组 shifts ,其中 shifts[i] = [starti, endi, directioni] 。对于每个 i ,将 s 中从下标 starti 到下标 endi (两者都包含)所有字符都进行移位运算,如果 directioni = 1 将字符向后移位,如果 directioni = 0 将字符向前移位。

将一个字符 向后 移位的意思是将这个字符用字母表中 下一个 字母替换(字母表视为环绕的,所以 'z' 变成 'a')。类似的,将一个字符 向前 移位的意思是将这个字符用字母表中 前一个 字母替换(字母表是环绕的,所以 'a' 变成 'z' )。

请你返回对 s 进行所有移位操作以后得到的最终字符串。

思路:

  • 构造一个差分数组记录每个元素需要前进或者后退
  • 记录每个点到97(a ) 的距离,根据距离获得对应的字母。
  • 注意:每个点到97的距离都要小于26. 记录sum为需要前进或后退的距离
    • sum为-4 时 , b - 4 -a = -3 因此 b + sum +26 -97
    • x + 2 根据上面 (b + sum +26 -97)%26
    • a +28 根据上面 sum%= 26,(b + sum +26 -97)%26
var shiftingLetters = function(s, shifts) {
    let len = s.length;
    let diff = new Array(len+1).fill(0);
    for(let i = 0;i<shifts.length;i++){
        const [start,end,val] = shifts[i];
        if(val>0){
            diff[start]++;
            diff[end+1]--;
        }else{
            diff[start]--;
            diff[end+1]++;
        }
    }
    let sum = 0;
    let strArr = s.split("");
    for(let i = 0;i<len;i++){
        sum+=diff[i];
        sum = sum%26;
        strArr[i] = String.fromCharCode((s[i].charCodeAt()+sum-97+26)%26+97);
    }
    return strArr.join("");
};

2406. 将区间分为最少组数

给你一个二维整数数组 intervals ,其中 intervals[i] = [lefti, righti] 表示 区间 [lefti, righti]

你需要将 intervals 划分为一个或者多个区间 ,每个区间 属于一个组,且同一个组中任意两个区间 不相交

请你返回 最少 需要划分成多少个组。

如果两个区间覆盖的范围有重叠(即至少有一个公共数字),那么我们称这两个区间是 相交 的。比方说区间 [1, 5][5, 8] 相交。

思路:

  • 求出重叠区间的最大个数,最少划分的组数 = 最大个数。
    • 理由:假如重叠区间最大个数为 m 个,分成 m +1 ,那么就说明新划分出来的组里的区间无法分到现有的m个分组里 ⇒ 与m个组里的线段都有重叠 ⇒ 那么最大重叠数就是 m + 1, 这和重叠区间最大个数为m个相违背。

      /**
       * @param {number[][]} intervals
       * @return {number}
       */
      var minGroups = function(intervals) {
          // 求最大重叠数
          intervals.sort((a, b) => b[1] - a[1])
          let len = intervals[0][1]
          let diff = new Array(len+1).fill(0)
          
          console.log(diff)
          for(let i = 0; i < intervals.length; i++){
             const [left, right] = intervals[i];
             diff[left-1]++;
             diff[right]--;
          }
         
          let sum = 0;
          let res = 0;
          for(let i = 0; i < diff.length-1; i++){
              sum += diff[i]
              res = Math.max(res, sum)
          }
          return res;
      };
      

d’d


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

相关文章:

  • vue自适应高度(缩放浏览器)
  • 使用 spring boot 2.5.6 版本时缺少 jvm 配置项
  • HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (二、首页轮播图懒加载的实现)
  • SparkSQL数据模型综合实践
  • 《鸿蒙Next微内核:解锁人工智能决策树并行计算的加速密码》
  • 10 为什么系统需要引入分布式、微服务架构
  • 如何在Windows系统上部署docker
  • PyTorch的 torch.unsqueeze() 和 torch.squeeze()方法详解
  • 黑豹程序员-封装组件-Vue3 setup方式子组件传值给父组件
  • 地下停车场智慧监查系统:科技让停车更智能
  • hexo和github.io博客的搭建
  • SpringBoot集成Flowable工作流
  • C++集群聊天服务器 网络模块+业务模块+CMake构建项目 笔记 (上)
  • Spring Boot(六十五):使用 ant.jar 执行 SQL 脚本文件
  • Windows下Node.js下载安装及环境变量配置教程
  • 陪诊小程序开发:重塑医疗服务体验,让关爱触手可及
  • 学习数据结构和算法的第3天
  • MySQL:关于存储过程
  • Packet Tracer - Configure IOS Intrusion Prevention System (IPS) Using the CLI
  • 第1章 简单使用 Linux
  • 空气质量预测 | Matlab实现基于SVR支持向量机回归的空气质量预测模型
  • 【RK3399 Android10, 支持温控风扇】
  • mysql关于left join关联查询时on和where条件区别
  • 数学建模:数据相关性分析(Pearson和 Spearman相关系数)含python实现
  • Kafka SASL_SSL双重认证
  • wins 安装 tensorflow keras