力扣每日一题:2734. 执行子串操作后的字典序最小字符串

题目链接

脑子比较笨,分三种情况考虑:

  1. 以a开头。
  2. xxa,a在中间。
    对于情况2还有两种可能:
    1. 全是a,最后一个元素需要替换成z,因为必须执行一次操作。
    2. aaaxxa,中间有一段非a,将这段改变即可。

垃圾实现代码:

cpp 复制代码
class Solution {
public:
    string smallestString(string s) {
        int fidx = -1, sidx = -1;
        string ans = "";
        for (int i = 0; i < s.size(); i ++ ) {
            if (s[i] == 'a') {
                fidx = i;
                break;
            }
        }
        if (fidx == 0) {// a 开头的
            int j = 0;
            while(s[j] == 'a') {
                j ++;
            }
            // j 第一个不是a的元素
            if (j == s.size()) { // 全是a
                for (int i = 0; i < s.size(); i ++ ) {
                    ans += s[i];
                }
                ans[s.size() - 1] = 'z';
                return ans;
            } else { // aaaa xxxxx a
                for (; j < s.size(); j ++ ) {
                    if (s[j] == 'a') {
                        sidx = j;
                        break;
                    }
                }
                for (int i = 0; i < s.size(); i ++ ) {
                    if (i < j && s[i] !='a') {
                        ans += (s[i] - 1);
                    } else {
                        ans += s[i];
                    }
                }
                return ans;
            }
        } else if (fidx != -1 ){ // bbb a
            for (int i = 0; i < s.size(); i ++ ) {
                if (i < fidx) {
                    ans += (s[i] - 1);
                } else {
                    ans += s[i];
                }
            }
            return ans;
        } else {
            for (int i = 0; i < s.size(); i ++ ) {
                ans += (s[i] - 1);
            }
            return ans;
        }
    }
};

灵神的代码(我的看起来好傻):

从左到右找到第一个不等于 a 的字符 s[i],然后从 i 开始,把每个字符都减一,直到遍历结束或者遇到了 a。例如 abca 操作中间的子串 bc,得到答案 aaba。

细节:如果 s 全为 a,由于题目要求必须操作一次,可以把最后一个 a 改成 z。

cpp 复制代码
class Solution {
public:
    string smallestString(string s) {
        int n = s.length();
        for (int i = 0; i < n; i++) {
            if (s[i] > 'a') {
                // 继续向后遍历
                for (; i < n && s[i] > 'a'; i++) {
                    s[i]--;
                }
                return s;
            }
        }
        // 所有字母均为 a
        s.back() = 'z';
        return s;
    }
};
相关推荐
一匹电信狗7 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
鱼跃鹰飞7 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
Queenie_Charlie7 小时前
小陶的疑惑2
数据结构·c++·树状数组
梵刹古音8 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
筵陌9 小时前
算法:模拟
算法
Queenie_Charlie9 小时前
小陶与杠铃片
数据结构·c++·树状数组
We་ct9 小时前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript
renhongxia19 小时前
AI算法实战:逻辑回归在风控场景中的应用
人工智能·深度学习·算法·机器学习·信息可视化·语言模型·逻辑回归
CoderCodingNo9 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法
民乐团扒谱机9 小时前
【AI笔记】精密光时频传递技术核心内容总结
人工智能·算法·光学频率梳