• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Задание по программированию в Pascal. Строки

Kot_Bayun

Ученик
Регистрация
15 Дек 2014
Сообщения
5
Реакции
0
Баллы
0
Задание по программированию в Pascal. Строки

Проблема с написанием программы. Помогите, прошу, иначе лабы сдать не смогу и вылечу из ВУЗа:polet:

Задание:
Строка – это правильное арифметическое выражение, содержащее только натуральные числа и знаки арифметических операций между ними (+, -, *, /). Подсчитать результат, выполняя арифметические операции в порядке их приоритета.

Входные данные:
5*3-9/3

Выходные данные:
12
 
Проблема с написанием программы. Помогите, прошу, иначе лабы сдать не смогу и вылечу из ВУЗа
Да ладно, живите:
Код:
Var
 Q:Array[1..100] of Word;
 R:Array[1..100] of Real;
 T:Array[1..100] of Char;
 S,P:String;
 i,j,Code,N:Word;

Function Sign(W:Char):boolean;
begin
 Sign:=(W='*') or (W='/') or (W='+') or (W='-');
end;

Begin
 Writeln('Enter the string:');
 Readln(S);
 N:=0;
 i:=0;
 Repeat
  P:='';
  Repeat
   Inc(i);
   If Not Sign(S[i]) then P:=P+S[i];
  Until Sign(S[i]) or (i=Length(S));
  Inc(N);
  Val(P,Q[N],Code);
  if i<Length(S) then T[N]:=S[i];
 Until i=Length(S);

 for i:=1 to N do R[i]:=Q[i];

 Repeat
  i:=0;
  Repeat
   Inc(i);
  Until (T[i]='*') or (T[i]='/') or (i=N-1);
  if (T[i]='*') or (T[i]='/') then
   begin
    if T[i]='*' then R[i]:=R[i]*R[i+1] else R[i]:=R[i]/R[i+1];
    for j:=i+1 to N-1 do R[j]:=R[j+1];
    for j:=i to N-2 do T[j]:=T[j+1];
    Dec(N);
   end;
 Until i>N-1;

 Repeat
  i:=0;
  Repeat
   Inc(i);
  Until (T[i]='+') or (T[i]='-') or (i>=N-1);
  if (T[i]='+') or (T[i]='-') then
   begin
    if T[i]='+' then R[i]:=R[i]+R[i+1] else R[i]:=R[i]-R[i+1];
    for j:=i+1 to N-1 do R[j]:=R[j+1];
    for j:=i to N-2 do T[j]:=T[j+1];
    Dec(N);
   end;
 Until i>N-1;

 Writeln(R[1]:0:5);

 Readln
End.
 
Назад
Сверху