Общее решение, позволяющее удалять из строк любой "мусор"
// PascalABC.Net 3.0, сборка 1066 procedure CheckString(var s:string; var n:integer); var i:integer; begin i:=Length(s); while i>0 do begin if not(s[i] in ['a'..'z']) then Delete(s,i,1); Dec(i) end; n:=Length(s) end;
var s1,s2:string; i,p,n1,n2:integer; begin Write('Введите первую строку: '); Readln(s1); CheckString(s1,n1); if n1=0 then Writeln('Введенная строка не содержит допустимых символов') else begin Write('Введите вторую строку: '); Readln(s2); CheckString(s2,n2); if n2=0 then Writeln('Введенная строка не содержит допустимых символов') else { теперь обе строки содержат только маленькие латинские буквы } if n1=n2 then begin for i:=1 to n1 do begin p:=Pos(s1[i],s2); if p=0 then Break else Delete(s2,p,1) end; if Length(s2)=0 then Writeln('Решение имеется') else Writeln('Решения нет') end else Writeln('Решения нет'); end end.
Тестовое решение: Введите первую строку: this is my own deal! Введите вторую строку: Тест: *is now=l2ead my sthi? Решение имеется
Также имеется современное решение, которому пока что в школах не учат: // PascalABC.Net 3.0, сборка 1066 begin var s1:=ReadString('Введите первую строку: ').Where(x->x in ['a'..'z']); if s1.Count=0 then Writeln('Введенная строка не содержит допустимых символов') else begin var s2:=ReadString('Введите вторую строку: ').Where(x->x in ['a'..'z']); if s2.Count=0 then Writeln('Введенная строка не содержит допустимых символов') else if s1.Except(s2).Count>0 then Writeln('Решения нет') else Writeln('Решение имеется') end end.
со строками можно работать так же, как и с элементами массива, т. е. мы можем обратиться к любому символу строки, как к элементу, можем сравнивать строки, складывать и вычитать( последние две операции здесь нам не понадобятся) №3. program ex3; var a,b:string; k,n,i:integer;{ввод исходных данных} begin writeln('введите первое слово'); readln(a); {компьютер читает введенное число a} writeln('введите второе слово'); readln(b); {компьютер читает введенное число b} k:=0; {обнуляем переменные k и n, это будут счетчики в данной программе} n:=0; for i:=1 to length(a) do { проверяем символы от первого до конца строки} k:=k+1; {если в строке находится символ, то переменная k увеличивается на 1} for i:=1 to length(b) do {аналогично} n:=n+1; if k>n {проверяем, если количество символов в первой строке больше, чем количество символов во второй, то выводим a(первое слово), иначе b (второе слово)} then writeln(a) else writeln(b); end.
№4program ex4; var a,b:string; i:integer; begin writeln('введите первое слово'); readln(a); writeln('введите второе слово'); readln(b); k:=0; n:=0; for i:= length(a) downto 1 do {просматриваю строку в обратном порядке и вывожу каждый символ на экран} write(a[i]); writeln; for i:=length(b) downto 1 do {просматриваю строку в обратном порядке и вывожу каждый символ на экран} write(b[i]); end.
№5 program ex3; var a:string; k,n,i:integer;{ввод исходных данных} begin writeln('введите слово'); readln(a); {компьютер читает введенное число a} k:=0; {обнуляем переменные k , это будут счетчики в данной программе}
for i:=1 to length(a) do { проверяем символы от первого до конца строки} k:=k+1; {если в строке находится символ, то переменная k увеличивается на 1} writeln(k); end.
№6. Задача аналогичная №3, за исключением условия в конце. program ex3; var a,b:string; k,n,i:integer;{ввод исходных данных} begin writeln('введите первое слово'); readln(a); {компьютер читает введенное число a} writeln('введите второе слово'); readln(b); {компьютер читает введенное число b} k:=0; {обнуляем переменные k и n, это будут счетчики в данной программе} n:=0; for i:=1 to length(a) do { проверяем символы от первого до конца строки} k:=k+1; {если в строке находится символ, то переменная k увеличивается на 1} for i:=1 to length(b) do {аналогично} n:=n+1; if k<n {проверяем, если количество символов в первой строке меньше, чем количество символов во второй, то выводим a(первое слово), иначе b (второе слово)} then writeln(a) else writeln(b); end.
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota
Оформи подписку