题目

in
3
2
ba
5
SORTS
10
Sarumanarm
out
case #0:
ab
case #1:
SORST
case #2:
Samranamru
思路
str[l]!=str[r]直接取小的值即可
str[l] == str[r]的时候
观察str[l + 1] 和str[r - 1]的区别
——取两者较小的部分
若str[l + 1] == str[r - 1]
——若str[l+1] > str[l],那么我们会取完两端再比较剩下的部分//所以这个拿哪个都无所谓
——若str[l+1] == str[l],我们继续比较l + 2和 r - 2的部分
——若str[l+1] < str[l],我们是先取完两边的相同的部分的其中一份,所以这里还得比较l + 2和 r - 2的部分
代码
#include<iostream>
using namespace std;
bool greedy(string s, int l, int r)
{
if(r - l == 1 || r -
最低0.47元/天 解锁文章
1636

被折叠的 条评论
为什么被折叠?



