powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / C++ [игнор отключен] [закрыт для гостей] / построение ПОЛИЗ по Lстроке
14 сообщений из 14, страница 1 из 1
построение ПОЛИЗ по Lстроке
    #34893231
Фотография FasterHarder
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
I started in 1983, in 2007 i still on a case!

Всем программистам привет! Respect! Вот необходимо построить ПОЛИЗ по Lстроке на С++(идентификаторы, знаки разные и т. п.), поискав в инете, понял что это такое. Ребята, может кто нибудь уже делал подобное, то дайте подсмотреть или ссылочку какую нить. Подскажите как быть то?
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893337
Фотография Gluk (Kazan)
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
чо
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893363
Фотография blinded
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Обратную польскую нотацию дядя хочет
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893371
Фотография Gluk (Kazan)
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ааа , ну дык спрашивать по умному нада, а не пальцы топырить
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893478
Фотография FasterHarder
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
I started in 1983, in 2007 i still on a case!

прошу прощения, что не расшифровал. ПОЛИЗ - польская инверсионная запись.
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893491
Фотография MasterZiv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
FasterHarder пишет:

Вот необходимо построить ПОЛИЗ по
> Lстроке на С++(идентификаторы, знаки разные и т. п.), поискав в инете,
> понял что это такое. Ребята, может кто нибудь уже делал подобное, то

Алгоритм Дейкстры поищи в сети.


ПОЛИЗ - польская инверсная запись для арифметических выражений.
Posted via ActualForum NNTP Server 1.4
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34893843
Фотография Gluk (Kazan)
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
блин, ссылку что правда никто кроме меня не видит ???
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34894332
egorych
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gluk (Kazan)блин, ссылку что правда никто кроме меня не видит ???да нет, у меня обе открылись... всё ровно
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34894786
Фотография MasterZiv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
FasterHarder пишет:
> Автор: "FasterHarder"
>
> I started in 1983, in 2007 i still on a case!
>
>
> Всем программистам привет! Respect! Вот необходимо построить ПОЛИЗ по
> Lстроке на С++(идентификаторы, знаки разные и т. п.), поискав в инете,
> понял что это такое. Ребята, может кто нибудь уже делал подобное, то

Posted via ActualForum NNTP Server 1.4
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34894859
Фотография Gluk (Kazan)
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
жость конечно, но если вдуматься, к теме вопроса отношения не имеет
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34961204
Фотография FasterHarder
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
I started in 1983, in 2007 i still on a case!

в общем нашел в инете некую реализацию ПОЛИЗа, но при компиляции возникает следующая бага, с которой сходу справиться не получилось:
Код: plaintext
Error	 2 	error C2440: '=' : cannot convert from 'void *' to 'st *'	c:\project_vs_2005\ 1 \ 1 \ 1 .cpp	 93 	
соответственно на строку кода:
Код: plaintext
  if((PTR=malloc(sizeof(struct st)))==NULL) 

на всякий чп выложу весть код. Подскажите как быть то? Буду очень признателен:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
#include<stdio.h>
#include<stdlib.h>

 /* Описание стpуктуpы(элемента стека) */
struct st                
{ char c;struct st *next;};
struct st *push(struct st *, char); 
/* Пpототипы функций */
char DEL(struct st **);
int PRIOR(char);

void main(void)
{
  /* Стек опеpаций пуст */
  struct st *OPERS=NULL;                     
  char a[ 80 ], outstring[ 80 ];
  int k, point;
  do
  { puts("Введите выpажение(в конце '='):");
    fflush(stdin);
	/* Ввод аpифметического выpажения */
    gets(a);                                 
    k=point= 0 ;
	  /* Повтоpяем , пока не дойдем до '=' */
    while(a[k]!='\0'&&a[k]!='=')           
    {
	/* Если очеpедной символ - ')' */
      if(a[k]==')')             
	             /* то выталкиваем из стека в выходную стpоку */
      {                                     
	          /* все знаки опеpаций до ближайшей */
        while((OPERS->c)!='(')         
		      /* откpывающей скобки */
        outstring[point++]=DEL(&OPERS);  
		      /* Удаляем из стека саму откpывающую скобку */
        DEL(&OPERS);
      }
	                /* Если очеpедной символ - буква , то */
      if(a[k]>='a'&&a[k]<='z')        
	          /* пеpеписываем её в выходную стpоку */
          outstring[point++]=a[k];        
		            /* Если очеpедной символ - '(' , то */
      if(a[k]=='(')                         
	          /* заталкиваем её в стек */
          OPERS=push(OPERS, '(');           
      if(a[k]=='+'||a[k]=='-'||a[k]=='/'||a[k]=='*')
	  /* Если следующий символ - знак опеpации , то: */
      {                             
	            /* если стек пуст */
        if(OPERS==NULL)                     
		 /* записываем в него опеpацию */
            OPERS=push(OPERS, a[k]);        
			 /* если не пуст */
        else                                 
/* если пpиоpитет поступившей опеpации больше 
               пpиоpитета опеpации на веpшине стека */
        if(PRIOR(OPERS->c)<PRIOR(a[k]))      
        /* заталкиваем поступившую опеpацию на стек */             
            OPERS=push(OPERS, a[k]);      
			       /* если пpиоpитет меньше */
        else                              
        {
          while((OPERS!=NULL)&&(PRIOR(OPERS->c)>=PRIOR(a[k])))
/* пеpеписываем в выходную стpоку все опеpации
                   с большим или pавным пpиоpитетом */
              outstring[point++]=DEL(&OPERS); 
			    /* записываем в стек поступившую  опеpацию */
          OPERS=push(OPERS, a[k]);           
        } 
      }
	  /* Пеpеход к следующему символу входной стpоки */
      k++;                                    
    }
	   /* после pассмотpения всего выpажения */
    while(OPERS!=NULL)                     
	 /* Пеpеписываем все опеpации из */
        outstring[point++]=DEL(&OPERS);    
		  /* стека в выходную стpоку */
    outstring[point]='\0';                    
	   /* и печатаем её */
    printf("\n%s\n", outstring);            
    fflush(stdin);
    puts("\nПовтоpить(y/n)?");
  } while(getchar()!='n');
}

/* Функция push записывает на стек (на веpшину котоpого указывает HEAD)
   символ a . Возвpащает указатель на новую веpшину стека */
struct st *push(struct st *HEAD, char a)
{
  struct st *PTR;
  /* Выделение памяти */
  if((PTR=malloc(sizeof(struct st)))==NULL) 
  {
  /* Если её нет - выход */
    puts("ет памяти");exit(- 1 );             
  }
  /* Инициализация созданной веpшины */
  PTR->c=a;                                
   /* и подключение её к стеку */
  PTR->next=HEAD;           
   /* PTR -новая веpшина стека */
  return PTR;                               
}

/* Функция DEL удаляет символ с веpшины стека.
   Возвpащает удаляемый символ.
   Изменяет указатель на веpшину стека */
char DEL(struct st **HEAD)
{
  struct st *PTR;
  char a;
  /* Если стек пуст,  возвpащается '\0' */
  if(*HEAD==NULL) return '\0'; 
  /* в PTR - адpес веpшины стека */
  PTR=*HEAD;                   
  a=PTR->c;
  /* Изменяем адpес веpшины стека */
  *HEAD=PTR->next;         
  /* Освобождение памяти */
  free(PTR);   
   /* Возвpат символа с веpшины стека */                
  return a;                   
}

/* Функция PRIOR возвpащает пpиоpитет аpифм. опеpации */
int PRIOR(char a)
{
  switch(a)
  {
    case '*':
    case '/':
         return  3 ;

    case '-':
    case '+':
         return  2 ;

    case '(':
         return  1 ;
  }
}
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34961230
Фотография Gluk (Kazan)
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
FasterHarder
Код: plaintext
  if((PTR=(st*)malloc(sizeof(struct st)))==NULL) 
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34961305
Фотография FasterHarder
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
I started in 1983, in 2007 i still on a case!

глубочайший респект Gluk (Kazan), вроде заработало. Thank's.
...
Рейтинг: 0 / 0
построение ПОЛИЗ по Lстроке
    #34962748
muk07
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Если ещё не пропал интерес, то в zip demo на C++Builder 5.
Poliz.cpp и Poliz.h нечувствительны к среде.
...
Рейтинг: 0 / 0
14 сообщений из 14, страница 1 из 1
Форумы / C++ [игнор отключен] [закрыт для гостей] / построение ПОЛИЗ по Lстроке
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]