leetcode 899. Orderly Queue

原题链接

You are given a string s and an integer k. You can choose one of the first k letters of s and append it at the end of the string.

Return the lexicographically smallest string you could have after applying the mentioned step any number of moves.

实际上如果k大于1,那么就会出现任意两个字符都能改变其在字符串中相对位置的情况,也就是能进行排序了。

如果k等于1,那么就找一个位置作为开始,遍历一下,找出字典序最小的那个排序就行。只是如果字符串中子串有规律,例如全是相同字符,或者重复出现ab之类的,那么就会出现最坏的情况,将这个最坏的情况优化掉。

复制代码
class Solution {
public:
    string orderlyQueue(string s, int k) {
        if (k ==0) return s;
        else if (k >1) {
            sort(s.begin(), s.end());
            return s;
        } else {
            int mn = 0,slen = s.size();
            for (int k = 1; k< slen; k++) {
                for(int l = 0; l < slen; l++) {
                    if (s[(k+l)%slen] < s[(mn+l)%slen]) {
                        mn = k;
                        break;
                    } else if (s[(k+l)%slen] > s[(mn+l)%slen]) {
                        break;
                    } else if (l == slen-1) return s.substr(mn) + s.substr(0, mn);
                }
            }
            return s.substr(mn) + s.substr(0, mn);
        }
    }
};
相关推荐
明月看潮生7 分钟前
青少年编程与数学 02-016 Python数据结构与算法 17课题、数论算法
python·算法·青少年编程·数论·编程与数学
合合技术团队9 分钟前
TextIn ParseX文档解析参数使用指南(第一期)
大数据·人工智能·算法·ocr·文档解析
懒懒小徐37 分钟前
大厂面试:六大排序
算法·排序算法
努力学习的小廉39 分钟前
【C++】 —— 笔试刷题day_18
开发语言·c++·算法
椰萝Yerosius1 小时前
[图论]生成树 引言
算法·图论
月亮被咬碎成星星1 小时前
LeetCode[28]找出字符串中第一个匹配项的下标(KMP版本)
算法·leetcode
小O的算法实验室1 小时前
2023年CCF-C NCA:自适应麻雀搜索算法MASSA,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
十年磨一剑~1 小时前
C实现md5功能
linux·算法
呈_现2 小时前
洛谷方格取数
算法
Dominic_Holmes2 小时前
代码随想录算法训练营Day30 | 01背包问题(卡码网46. 携带研究材料)、Leetcode416.分割等和子集
数据结构·python·算法·leetcode