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

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

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

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

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


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

Posted via ActualForum NNTP Server 1.4
...
Рейтинг: 0 / 0
25.10.2007, 16:05:55
    #34894859
Gluk (Kazan)
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
построение ПОЛИЗ по Lстроке
жость конечно, но если вдуматься, к теме вопроса отношения не имеет
...
Рейтинг: 0 / 0
23.11.2007, 13:53:45
    #34961204
FasterHarder
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
построение ПОЛИЗ по Lстроке
Код: 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
23.11.2007, 13:58:46
    #34961230
Gluk (Kazan)
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
построение ПОЛИЗ по Lстроке
FasterHarder
Код: plaintext
  if((PTR=(st*)malloc(sizeof(struct st)))==NULL) 
...
Рейтинг: 0 / 0
23.11.2007, 14:12:54
    #34961305
FasterHarder
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
построение ПОЛИЗ по Lстроке
Код: plaintext
I started in 1983, in 2007 i still on a case!

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


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