力扣每日一题: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;
    }
};
相关推荐
无限空间之王1 分钟前
我让三个 AI 互相竞争进化,两天后它们发明了一个我看不懂的算法
算法
sinat_255487819 分钟前
为 System.out 编写我们自己的包装类
java·开发语言·算法
阿Y加油吧20 分钟前
力扣打卡——盛最多水的容器、三数之和
算法·leetcode·排序算法
Barkamin25 分钟前
快速排序非递归实现
java·算法·排序算法
gihigo199829 分钟前
距离角度解耦法的MIMO-OFDM雷达波束形成及优化MATLAB实现
开发语言·算法·matlab
WolfGang00732129 分钟前
代码随想录算法训练营 Day12 | 二叉树 part02
算法·深度优先
愚者游世32 分钟前
Qt 基础认知
c++·学习·程序人生·职场和发展·visual studio
2401_8535765035 分钟前
代码自动生成框架
开发语言·c++·算法
逆境不可逃41 分钟前
【从零入门23种设计模式23】行为型之模板模式
java·开发语言·算法·设计模式·职场和发展·模板模式
ZPC821042 分钟前
PPO 在ROS2 中训练与推理
人工智能·算法·机器人