力扣每日一题: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;
    }
};
相关推荐
眼镜哥(with glasses)25 分钟前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
zh_xuan3 小时前
c++ 单例模式
开发语言·c++·单例模式
int型码农5 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
利刃大大5 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
UFIT5 小时前
NoSQL之redis哨兵
java·前端·算法
喜欢吃燃面5 小时前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked935 小时前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise
怀旧,5 小时前
【数据结构】6. 时间与空间复杂度
java·数据结构·算法
积极向上的向日葵6 小时前
有效的括号题解
数据结构·算法·
GIS小天6 小时前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年6月7日第101弹
人工智能·算法·机器学习·彩票