LeetCode1221.分割平衡字符串&1894.找到需要补充粉笔的学生编号(C++)

前言

一个普通解法的简单题LeetCode1221.分割平衡字符串
一个普通解法的中等题LeetCode1894.找到需要补充粉笔的学生编号

LeetCode1221.分割平衡字符串

点击链接开始刷题φ(゜▽゜*)♪:LeetCode1221.分割平衡字符串

解题思路

直接遍历字符串
遇到 R,就使 r 计数加一;
遇到 L,就使 l 计数加一;
r==l 的时候,说明出现了一个 RL 数量相等的子串,可以把它分割出去,
所以使 count 计数加一,并且使 rl 重新归 0,进行下一轮的计数;
最后 count 的值就是可以通过分割得到的平衡字符串的最大数量。

代码

class Solution {
public:
    int balancedStringSplit(string s) {
        int count = 0; //可以通过分割得到的平衡字符串的最大数量
        int r = 0; //R的数量
        int l = 0; //L的数量
        for(int i=0;i<s.size();++i){
            if(s[i]=='R')
                ++r;
            else if(s[i]=='L')
                ++l;
            if(r==l){
                r = 0;
                l = 0;
                ++count;
            }
        }
        return count;
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

LeetCode1894.找到需要补充粉笔的学生编号

点击链接开始刷题φ(゜▽゜*)♪:LeetCode1894.找到需要补充粉笔的学生编号

解题思路

因为老师是一直重复这个过程的,可能会有很多很多轮回,直到粉笔不够
所以先遍历一遍数组 chalk,把一轮下来学生需要的粉笔总数算出来
然后将 ksum 进行取模
就会得到最后一轮开始时还剩余的粉笔数量
这些粉笔一定会在这最后一轮消耗完毕
所以只要再遍历一次数组 chalk
每次 k 都减去 chalk[i],直到 k<chalk[i],则返回 i
因为粉笔一定会在最后一轮消耗完,所以必然是从 return i 处结束这个函数
根本不会执行到 return 0 这一行,所以写 return -1 啥的也行~

代码

class Solution {
public:
    int chalkReplacer(vector<int>& chalk, int k) {
        int len = chalk.size();
        long sum = 0;
        for(int i=0;i<len;++i){
            sum += chalk[i];
        }
        k = (int)k%sum;    //取模
        for(int i=0;i<len;++i){
            if(k<chalk[i])
                return i;  //最后肯定是从这里返回结果
            k -= chalk[i];
        }
        return 0;  //不会执行到这里
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

微信公众号文章

LeetCode1221.分割平衡字符串&1894.找到需要补充粉笔的学生编号

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dululuya

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值