Advertisement
Guest User

Untitled

a guest
Dec 7th, 2016
65
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.94 KB | None | 0 0
  1. #include "stdafx.h"
  2. #include <iostream>
  3. #include <cstdio>
  4. #include <iomanip>
  5. #include <conio.h>
  6. #include <stdlib.h>
  7. #include <time.h>
  8. #include <cstdlib>
  9. #include <stdio.h>
  10. #include <conio.h>
  11. #include <allocators>
  12.  
  13.  
  14. struct Stack {
  15.     char info; Stack *next;
  16. }  *begin;
  17. float mas[256];
  18. void main()
  19. {
  20.     Stack* InStack(Stack*, char);
  21.     Stack* OutStack(Stack*, char*);
  22.     int Prior(char);
  23.  
  24.     double Rezult(char[]);
  25.     char InStr[256], OutStr[256] = " ";
  26.     rand();
  27.     unsigned int i, l = 0;
  28.     srand(time(NULL));
  29.     char ss, a;
  30.     Stack *t; begin = NULL;
  31.     puts("vvedi formulu"); gets_s(InStr);
  32.     //  ИЛИ strcpy(InStr,"a+b*(c-d)/e");
  33.     for (i = 0; i<strlen(InStr); i++)
  34.     {
  35.         ss = InStr[i];
  36.         if (ss == '(')  begin = InStack(begin, ss);
  37.         if (ss == ')') {
  38.             while ((begin->info) != '(') {
  39.                 begin = OutStack(begin, &a); //Считываем элемент из стека
  40.                 if (!begin) a = '\0';  OutStr[l++] = a; // Записываем в строку
  41.             }
  42.             begin = OutStack(begin, &a);//Удаляем из стека '(' скобку
  43.                                         //  t=begin; begin=begin->next;  free(t);
  44.         }
  45.         // Букву (операнд) заносим в выходную строку
  46.         if (ss >= 'a' && ss <= 'z') OutStr[l++] = ss; // OutStr += ss;
  47.                                                       /* Если знак операции, то переписываем из стека в вых строку все оп-ции с большим или равным приоритетом */
  48.         if (ss == '+' || ss == '-' || ss == '*' || ss == '/')
  49.         {
  50.             while (begin != NULL && Prior(begin->info) >= Prior(ss))
  51.             {
  52.                 begin = OutStack(begin, &a);  OutStr[l++] = a;      //OutStr += a;
  53.             }
  54.             begin = InStack(begin, ss);
  55.         }
  56.     }
  57.     // Если стек не пуст, переписываем все операции в выходную строку
  58.     while (begin != NULL)
  59.     {
  60.         begin = OutStack(begin, &a); OutStr[l++] = a;
  61.         //OutStr += a;
  62.     }
  63.     OutStr[l] = '\0';
  64.     printf("\n OPZ->%s\n", OutStr); // Выводим полученную строку
  65.     puts(OutStr);
  66.     float f = Rezult(OutStr);
  67.     printf(" \nf=%5.2f", f);
  68.     getch();
  69. }
  70. //-------- Функция реализации приоритета операций-----------
  71. int Prior(char a) {
  72.     switch (a) {
  73.     case '^':           return 4;
  74.     case '*':   case '/':   return 3;
  75.     case '-':   case '+':   return 2;
  76.     case '(':           return 1;
  77.     }
  78.     return 0;
  79. }
  80.  
  81. Stack* InStack(Stack *p, char in)
  82. {
  83.     Stack *t = (Stack*)malloc(sizeof(Stack));
  84.     t->info = in;
  85.     t->next = p;
  86.     return t;
  87. }
  88. //
  89. Stack* OutStack(Stack* p, char *out) {
  90.     Stack *t = p;      // Устанавливаем указатель t на вершину p
  91.     *out = p->info;
  92.     p = p->next;   // Переставляем вершину p на следующий элемент
  93.     delete t;     // Удаляем бывшую вершину t
  94.     return p;     // Возвращаем новую вершину p
  95. }
  96. double Rezult(char Str[]) {
  97.     char ch, ch1, ch2;
  98.     float op1, op2, rez;
  99.     float a, b, c, d, e, f;
  100.     char chr = 'z' + 1;  unsigned ind = 97;
  101.     printf("\na="); scanf("%f", &a); mas[ind] = a;
  102.     printf("\nb="); scanf("%f", &b); mas[ind + 1] = b;
  103.     printf("\nc="); scanf("%f", &c); mas[ind + 2] = c;
  104.     printf("\nd="); scanf("%f", &d); mas[ind + 3] = d;
  105.     printf("\ne="); scanf("%f", &e); mas[ind + 4] = e;
  106.     for (unsigned i = 0; i < strlen(Str); i++)
  107.     {
  108.         ch = Str[i];
  109.  
  110.         if (ch != '-' && ch != '+' && ch != '*' && ch != '/')
  111.             begin = InStack(begin, ch);
  112.         else {
  113.             begin = OutStack(begin, &ch1);
  114.             begin = OutStack(begin, &ch2);
  115.             op1 = mas[(unsigned)ch1];
  116.             op2 = mas[(unsigned)ch2];
  117.             printf("\n op1=%5.2f,  op2=%5.2f, ch=%c \n", op1, op2, ch);
  118.             switch (ch) {
  119.             case '+':   rez = op2 + op1;        break;
  120.             case '-':   rez = op2 - op1;        break;
  121.             case '*':   rez = op2*op1;          break;
  122.             case '/':   rez = op2 / op1;        break;
  123.                 //                  case '^' :  rez=pow(op2,op1);   break;
  124.             }
  125.             mas[(unsigned)chr] = rez;
  126.             begin = InStack(begin, chr);
  127.             chr++;
  128.         }
  129.     }
  130.     return rez;
  131. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement