На обработку поступает последовательность из n натуральных чисел. на вход программе сначала подается само число n, потом вводятся n чисел. нужно написать программу, которая выводит на экран наименьшее трехзначное число, оканчивающееся на 6, если такое число было найдено, или фразу «не найдено», если такого числа в последовательности нет. на питоне
class NumProcessor():
def __init__(self, length, endSymb):
self.main_buffer = []
self.search_lengt = length
self.search_endSymbol = endSymb
def addNum(self, *nums):
for num in nums:
self.main_buffer.append(num)
def sortLen(self, length, array):
for item in array:
if len(str(item)) == length:
yield item
def sortEndSymb(self, symbol, array):
for item in array:
if str(item)[-1] == str(symbol):
yield item
def sort(self):
servBufferlen = [int(i) for i in self.sortLen(self.search_lengt, self.main_buffer)]
servBufferendSym = [int(i) for i in self.sortEndSymb(self.search_endSymbol, servBufferlen)]
return min(servBufferendSym)
def insert_nums():
result = []
print('What count of numbers you want to process?\n')
n = int(input())
for i in range(n):
result.append(input())
return result
def main():
processor = NumProcessor(3, '6')
processor.addNum(*insert_nums())
result = processor.sort()
if len(result) == 0:
print('НЕ НАЙДЕНО')
else:
print(result)
if __name__ == '__main__':
main()
input()
Объяснение:
Код протестирован и работает. Копировать с сайта не нужно, ибо ломаются табуляции в коде. Вы можете ознакомиться с решением задания и попытаться повторить это самостоятельно, или попросить в комментариях меня, я залью этот код на pastebin.com и дам вам ссылку, оттуда можно спокойно будет скопировать решение. Ниже приложен скриншот оригинала кода