// PascalABC.NET 3.0, сборка 1128 const nmax=100; var n,i,j,nn,nz,np,t:integer; a,an,az,ap:array[1..nmax] of integer; begin // формируем массив и выводим его Write('Количество элементов в массиве: '); Read(n); for i:=1 to n do begin a[i]:=Random(11)-5; Write(a[i],' ') end; Writeln; // разбиваем массив на три подмассива nn:=0; nz:=0; np:=0; for i:=1 to n do if a[i]<0 then begin nn:=nn+1; an[nn]:=a[i] end else if a[i]=0 then begin nz:=nz+1; az[nz]:=a[i] end else begin np:=np+1; ap[np]:=a[i] end; // сортируем массив с отрицательными элементами по убыванию for i:=1 to nn-1 do for j:=1 to nn-1 do if an[j]<an[j+1] then begin t:=an[j]; an[j]:=an[j+1]; an[j+1]:=t end; // сортируем массив с положительными элементами по возрастанию for i:=1 to np-1 do for j:=1 to np-1 do if ap[j]>ap[j+1] then begin t:=ap[j]; ap[j]:=ap[j+1]; ap[j+1]:=t end; // формируем новое содержимое массива a i:=0; for j:=1 to nz do begin i:=i+1; a[i]:=az[j] end; for j:=1 to np do begin i:=i+1; a[i]:=ap[j] end; for j:=1 to nn do begin i:=i+1; a[i]:=an[j] end; // вывод результата for i:=1 to n do Write(a[i],' '); Writeln end.
1. var x,y:integer; begin write('x = '); readln(x); if x>0 then y:=1 else if x=0 then y:=0 else y:=-1; writeln('y = ',y); end.
Пример: x = -5 y = -1
2. var a,b,c,x1,x2,d:real; begin writeln('Введите a, b, c:'); readln(a,b,c); d:=b*b-4*a*c; if d>0 then begin x1:=(-b+sqrt(d))/(2*a); x2:=(-b-sqrt(d))/(2*a); writeln('x1 = ',x1,' x2 = ',x2); end else if d=0 then begin x1:=-b/(2*a); writeln('x = ',x1); end else writeln('Корней нет'); end.
Пример: Введите a, b, c: 2 5 -3 x1 = 0.5 x2 = -3
3. var a,b,c:real; begin writeln('Введите a, b, c:'); readln(a,b,c); if (a<=b)and(b<=c) then begin b:=a; c:=a; end else begin a:=-a; b:=-b; c:=-c; end; writeln('a = ',a,' b = ',b,' c = ',c); end.
Пример 1: Введите a, b, c: 2 5 9 a = 2 b = 2 c = 2
Пример 2: Введите a, b, c: 2 9 5 a = -2 b = -9 c = -5
Дворічні: дудник лісовий
Багаторічні: костяниця