Чтобы сделать алгоритм поиска подстроки @blhsing опубликованным немного проще для чтения, вы можете просто разделить шаги на их собственные циклы. Это та же логика, но не в одной строке.
setC = set()
sortedList = sorted(setA, key=len)
for substring in sortedList:
if not substring_in_set(substring, set3):
setC.add(substring)
# Checks whether the subtrings is in the set
# and returns True or False
def substring_in_set(substring, set):
for i in range(len(substring)):
for n in range(len(substring) - i):
if substring[i: i + n + 1] in set:
return True
return False
Да, с" запечатанным ":
class A
{
abstract void DoAction();
}
class B : A
{
sealed override void DoAction()
{
// Implements action in a way that it doesn't make
// sense for children to override, e.g. by setting private state
// later operations depend on
}
}
class C: B
{
override void DoAction() { } // will not compile
}
Вы можете пометить метод как запечатанный
.
http://msdn.microsoft.com/en-us/library/aa645769 (VS.71). aspx
class A
{
public virtual void F() { }
}
class B : A
{
public sealed override void F() { }
}
class C : B
{
public override void F() { } // Compilation error - 'C.F()': cannot override
// inherited member 'B.F()' because it is sealed
}
Отдельные методы могут быть помечены как закрытые, что в целом эквивалентно маркировке метода как окончательного в Java. Итак, в вашем примере вы должны иметь:
class B : A
{
override sealed void DoAction()
{
// implementation
}
}