procedure inverse(var s:string);
var buf:string;
i:byte;
begin
buf:='';
for i:=length(s) downto 1 do
buf:=buf+s[i];
s:=buf;
end;
uses CRT;
var I, J: integer;
S, S1, S2: string;
begin
ClrScr;
write('S=');
read(S);
S:=S+' ';
I:=1;
while I<=length(S) do
begin
if S[I]=' ' then
begin
S1:=Copy(S, 1, I);
delete(S, 1, I);
for J:=length(S1) downto 1 do
S2:=S2+S1[J];
I:=1;
S2:=S2+' ';
end;
I:=I+1;
end;
writeln(S2);
readkey;
end.
n := length(s);
for i := 1 to n div 2 do begin
temp := s[i];
s[i] := s[n - i + 1];
s[n - i + 1] := temp;
end;
// где s - слово
type
main=array[1..40] of string[50];
procedure take_words(s:string; var mas:main; var n:integer);
var i:byte;
begin
n:=1;
for i:=1 to length(s) do
if (s[i]=' ') and (i<>length(s)) then
inc(n)
else
mas[n]:=mas[n]+s[i];
end;
procedure inverse(var s:string);
var buf:string;
i:byte;
begin
buf:='';
for i:=length(s) downto 1 do
buf:=buf+s[i];
s:=buf;
end;
var s:string; mas:main; n,i:integer;
begin
writeln('Enter string');
readln(s);
take_words(s,mas,n);
for i:=1 to n do
begin
inverse(mas[i]);
write(mas[i],' ');
end;
readln;
end.
var
ch: char;
s: string;
start, finish, i: integer;
begin
write('s = '); readln(s);
start := 1;
while start <= length(s) do begin
while (start <= length(s)) and (s[start] = ' ') do inc(start);
finish := start;
while (finish <= length(s)) and (s[finish] <> ' ') do inc(finish);
for i := 1 to (finish - start) div 2 do begin
ch := s[start + i - 1];
s[start + i - 1] := s[finish - i];
s[finish - i] := ch;
end;
start := finish;
end;
writeln(s);
end.