C ++中按字典顺序的最后一个子字符串
假设我们以s作为字符串,我们必须按字典顺序查找s的最后一个子字符串。
因此,如果输入像“abbbcabbc”,那么输出将是“cabbc”
为了解决这个问题,我们将遵循以下步骤-
i:=0,j:=1,k:=0
而j+k<s的大小,做&minsu;
j:=j+k+1
i:=j
(将j增加1)
(将k增加1)
忽略以下部分,跳至下一个迭代
如果s[i+k]与s[j+k]相同,则-
如果s[i+k]<s[j+k],则-
除此以外
k:=0
从索引i返回s的子字符串到结尾
让我们看下面的实现以更好地理解-
示例
#include <bits/stdc++.h>
using namespace std;
class Solution {
   public:
   string lastSubstring(string s) {
      int i = 0;
      int j = 1;
      int k = 0;
      while(j + k < s.size()){
         if(s[i + k] == s[j + k]) {
            k++;
            continue;
         }
         if(s[i + k] < s[j + k]){
            i = j;
            j++;
         }else{
            j = j + k + 1;
         }
         k = 0;
      }
      return s.substr(i, s.size() - i);
   }
};
main(){
   Solution ob;
   cout << (ob.lastSubstring("abbbcabbc"));
}输入值
"abbbcabbc"
输出结果
cabbc