// PascalABC.NET 3.1, сборка 1250 от 28.05.2016 begin var a:=ArrRandom(30,1960,2016); a.Println; var iFirst:=a.IndexMin; var iLast:=iFirst; var vMin:=a[iFirst]; for var i:=29 downto iFirst+1 do if a[i]=vMin then begin iLast:=i; break end; if iLast=iFirst then Writeln('Самый старший человек номер ',iFirst+1) else Writeln('Первый из самых старших людей имеет номер ', iFirst+1,', последний из людей этого возраста - номер ', iLast+1) end.
Тестовое решение 1987 1971 1974 1989 1989 1960 1987 2016 1992 1962 1971 2011 1993 1962 2008 1994 1994 1976 1988 2014 2011 1960 1971 2000 1973 2010 1964 1976 1971 1993 Первый из самых старших людей имеет номер 6, последний из людей этого возраста - номер 22
Вот так эту задачу можно решить на современном Паскале. Но, к сожалению, так в школах не учат, заставляя тратить время и силы на громоздкие программы, в которых легко ошибиться.
// PascalABC.Net 3.2
begin Write(ReadlnString('->').ToWords.Where(x->x.Left(2)='со').Count) end.
Пример: -> Три собаки сосали одну косточку 2
А вот так (примерно, потому что обычно еще хуже) учат писать программы в школе...
var s:string; i,n,k,p:integer; begin Write('->'); Readln(s); if Copy(s,1,2)='со' then k:=1 else k:=0; Delete(s,1,3); repeat i:=Pos(' со',s); if i>0 then begin Inc(k); Delete(s,1,i+3) end until i=0; Writeln(k) end.
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota
Оформи подписку