Словесный: получим значения a, b и c, вычислим дискриминант по формуле D := b * b - 4 * a * c, Вычислим корни по формуле X := (-1 * b + sqrt(D) )/ 2 * a
Надеюсь в блок-схеме разберешься какие скобки какую фигуру обозначают... В этих алгоритмах я брал только случаи, когда D строго больше нуля. Ты можешь дополнительно добавить ветвление после нахождения D и добавить все условия. Я просто на этом окне никак это не сделаю. Программа будет с ветвлением.
Программа: var a, b, c, D, X: real; begin write('Введите A: '); read(a); write('Введите B: '); read(b); write('Введите C: '); read(c); D := sqr(b) - 4 * a * c; if D > 0 then begin X := (-1 * b + sqrt(D)) / 2 * a; writeln('X1 = ', X); X := (-1 * b - sqrt(D)) / 2 * a; writeln('X2 = ', X); end else if D = 0 then begin X := (-1 * b + sqrt(D)) / 2 * a; write('X = ', X); end else write('Корней нет!'); end.
В СССР доступные бытовые магнитофоны распространились примерно со второй половины 1950-х — начала 1960-х годов. В это время возникло особое социальное явление — магнитофонная культура или «магнитиздат». Легкость копирования магнитных записей позволила почти неограниченно распространять произведения, не одобрявшиеся официальной идеологией, но популярные в народе: песни бардов и первых полуподпольных рок-групп, западную популярную музыку, неофициальные выступления писателей-сатириков, лекции по уфологии, передачи «вражеских голосов» и т. п.[30][31] Магнитофоны быстро вытеснили с рынка кустарную грамзапись — грампластинки, записанные на использованной рентгенопленке («музыка на ребрах»).
Var s:string; d1,m1,g1,d2,m2,g2,t,c:integer; p:boolean; k:byte;begin k:=0; writeln('Введите дату в формате дд.мм.гг');readln(s); val(copy(s,7,2),t,c);{преобразуем год в число}if (c<>0)or(t<0) then k:=1 else g1:=t;{определим високосный год или нет}if (((g1+2000) mod 100<>0)and((g1+2000) mod 4=0))or((g1+2000) mod 400=0) then p:=trueelse p:=false; val(copy(s,4,2),t,c);if (c<>0)or not(t in [1..12]) then k:=1 else m1:=t; val(copy(s,1,2),t,c);if (c<>0)or((m1 in [1,3,5,7,8,10,12])and not(t in [1..31])) or((m1 in [4,6,9,11])and not(t in [1..30])) or(p and(m1=2)and not(t in [1..29])) or(not p and(m1=2)and not(t in [1..28]))then k:=1 else d1:=t;if k=1 thenbeginwriteln('Дата введена неверно!');endelsebeginif(m1=1)and(d1=1)then begin d2:=31; m2:=12; g2:=g1-1; end else if ((m1 in [5,7,10,12]) and(d1=1))then begin d2:=30; m2:=m1-1; g2:=g1; end else if ((m1 in [2,4,6,8,9,11]) and(d1=1))then begin d2:=31; m2:=m1-1; g2:=g1; end else if(m1=3)and (d1=1) then begin if p then d2:=29 else d2:=28; m2:=m1-1; g2:=g1; end else begin d2:=d1-1; m2:=m1; g2:=g1; end;writeln('Предыдущая дата:');if d2<10 then write('0',d2,'.')else write(d2,'.');if m2<10 then write('0',m2,'.')else write(m2,'.');write(g2);end;end.
получим значения a, b и c, вычислим дискриминант по формуле D := b * b - 4 * a * c, Вычислим корни по формуле X := (-1 * b + sqrt(D) )/ 2 * a
Блок-схема:
(НАЧАЛО)
/Ввод a/
/Ввод b/
/Ввод c/
[D := sqr(b) - 4 * a * c]
[X := (-1 * b + sqrt(b)) / 2 * a]
/Вывод X/
[X := (-1 * b - sqrt(b)) / 2 * a]
/Вывод X/
(КОНЕЦ)
Надеюсь в блок-схеме разберешься какие скобки какую фигуру обозначают... В этих алгоритмах я брал только случаи, когда D строго больше нуля. Ты можешь дополнительно добавить ветвление после нахождения D и добавить все условия. Я просто на этом окне никак это не сделаю. Программа будет с ветвлением.
Программа:
var
a, b, c, D, X: real;
begin
write('Введите A: ');
read(a);
write('Введите B: ');
read(b);
write('Введите C: ');
read(c);
D := sqr(b) - 4 * a * c;
if D > 0 then
begin
X := (-1 * b + sqrt(D)) / 2 * a;
writeln('X1 = ', X);
X := (-1 * b - sqrt(D)) / 2 * a;
writeln('X2 = ', X);
end else if D = 0 then
begin
X := (-1 * b + sqrt(D)) / 2 * a;
write('X = ', X);
end else write('Корней нет!');
end.
(Протестировано, работает!)