У меня есть этот код, который я нашел в другой теме, но он сортирует подстроку смежными символами, а не в алфавитном порядке. Как исправить его в алфавитном порядке? Он печатает lk
, и я хочу напечатать ccl
. БлагодаряНайти самую длинную подстроку в алфавитном порядке
пс: Я новичок в Python
s = 'cyqfjhcclkbxpbojgkar'
from itertools import count
def long_alphabet(input_string):
maxsubstr = input_string[0:0] # empty slice (to accept subclasses of str)
for start in range(len(input_string)): # O(n)
for end in count(start + len(maxsubstr) + 1): # O(m)
substr = input_string[start:end] # O(m)
if len(set(substr)) != (end - start): # found duplicates or EOS
break
if (ord(max(sorted(substr))) - ord(min(sorted(substr))) + 1) == len(substr):
maxsubstr = substr
return maxsubstr
bla = (long_alphabet(s))
print "Longest substring in alphabetical order is: %s" %bla
Что означает "длинный в алфавитном порядке" означает? Как одно значение, которое вы печатаете, должно быть в любом порядке? –
Эй, добро пожаловать в StackOverflow! Мы с большей вероятностью можем помочь вам, если вы сами поймаете проблему и [описате, что вы пробовали] (http://whathaveyoutried.com). Проверьте «Переполнение стека [контрольный список вопросов]» (http://meta.stackexchange.com/questions/156810/stack-overflow-question-checklist) для получения дополнительной информации о задании правильных вопросов. Удачи и счастливого кодирования! –
Привет, спасибо за ваши ответы: Например, если s = 'tjkocgygiwc', самая длинная подстрока в алфавитном порядке - это jko, я не сейчас, как это сделать, чтобы найти это «jko», программа находит jk. С «wvcdcgykkaypy» он находит «wv», а не «cgy» – spacegame