力扣每日一题: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 小时前
第九章-数字三角形
算法
在路上看风景7 小时前
19. 成员初始化列表和初始化对象
c++
uesowys7 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
zmzb01037 小时前
C++课后习题训练记录Day98
开发语言·c++
ValhallaCoder7 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮7 小时前
AI 视觉连载1:像素
算法
念风零壹7 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
智驱力人工智能7 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥8 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风8 小时前
代码随想录第十五天
数据结构·算法·leetcode