Задача 1. Код, предложенный Budzsergiy777p0i27m наиболее подходит для решения, если слова разделены только одним пробелом. Решение задачи ниже аналогично (удалить пробелы в начале и в конце строки, затем посчитать пробелы, увеличить на 1 результат и вывести на экран)
Программа: print(input().strip().count(' ')+1)
Задача 2. Здесь следует учесть, что строка является неизменяемым элементом, т.е. напрямую символ в строке изменить нельзя, но можно получить два среза строки до и после буквы 'h' и затем склеить первый срез + большая буква 'H' + второй срез. Например, строка 'abchdef' -> 'abc'+'H'+'def'. А чтобы не захватить первую и последнюю букву h, нужно найти их индексы в строке и затем обрабатывать только часть строки между первой и последней буквой h.
Программа:
x=input() #ввод строки n1=x.find('h') #находим индекс первого вхождения буквы h n2=x.rfind('h') #находим индекс последнего вхождения буквы hy=x[n1+1:n2] #выбираем срез строки после первого вхождения #буквы h и до последнего вхождения буквы h while y.find('h')!=-1: #пока в срезе есть буква h y=y[:y.find('h')]+'H'+y[y.find('h')+1:] #заменить малую букву h на H print(x[:n1+1]+y+x[n2:]) #вывод строки до первой буквы h+результат #замен в срезе h на H + вывод строки после # последней буквы h
В однобайтовом формате (8 бит) можно хранить 2^8 = 256 значений- от нуля до 255.
Если там посчитать 0 - 1, то байт перейдёт к значению 255. А если посчитать 255 + 1, то байт перейдёт к нулевому значению (т.е. 255 + 1 = 0 ). Поэтому, можно рассматривать 255 как минус единицу (ведь -1 + 1 = 0 ).
Так же и для минус семнадцати: 256 - 17 = 239
Если к 239 прибавить 17, то получим ноль в байте, так как 256 там не бывает, произойдёт перенос единицы в следующий байт (либо в бит признака переноса), а в этом байте останутся нули во всех битах.
Программа:
print(input().strip().count(' ')+1)
Задача 2. Здесь следует учесть, что строка является неизменяемым элементом, т.е. напрямую символ в строке изменить нельзя, но можно получить два среза строки до и после буквы 'h' и затем склеить первый срез + большая буква 'H' + второй срез. Например, строка
'abchdef' -> 'abc'+'H'+'def'. А чтобы не захватить первую и последнюю букву h, нужно найти их индексы в строке и затем обрабатывать только часть строки между первой и последней буквой h.
Программа:
x=input() #ввод строки
n1=x.find('h') #находим индекс первого вхождения буквы h
n2=x.rfind('h') #находим индекс последнего вхождения буквы hy=x[n1+1:n2] #выбираем срез строки после первого вхождения
#буквы h и до последнего вхождения буквы h
while y.find('h')!=-1: #пока в срезе есть буква h y=y[:y.find('h')]+'H'+y[y.find('h')+1:] #заменить малую букву h на H
print(x[:n1+1]+y+x[n2:]) #вывод строки до первой буквы h+результат
#замен в срезе h на H + вывод строки после
# последней буквы h
Если там посчитать 0 - 1, то байт перейдёт к значению 255.
А если посчитать 255 + 1, то байт перейдёт к нулевому значению
(т.е. 255 + 1 = 0 ).
Поэтому, можно рассматривать 255 как минус единицу (ведь -1 + 1 = 0 ).
Так же и для минус семнадцати:
256 - 17 = 239
Если к 239 прибавить 17, то получим ноль в байте, так как 256 там не бывает, произойдёт перенос единицы в следующий байт (либо в бит признака переноса), а в этом байте останутся нули во всех битах.
ответ: 239