Описание работы программы
Структура StrArray:
Состоит из двух элементов: динамического массива строк (** item) и переменной (counti), в которую записывается количество строк в массиве.
Функция short add_item(struct StrArray* array, char* new_item):
Выделяет память и добавляет новую строку в массив item.
Процедура void free_items(struct StrArray* array):
Освобождает память выделенную под массив item.
Процедура void GetItems(const char* s, struct StrArray *InputItems):
Принимает строку sи выбирает из нее «слова/данные» разделенные любым кол-вом пробелов или символов табуляций. Затем записывает выделенные «слова/данные» в массивInputItems.item.
Инициализируем индекс CurCh для обхода строк
Инициализируем флаг separat которые показывает что был встречен разделитель (символ пробела или таба)
Инициализируем строку в которой будем собирать текущее слово
Очищаем CurItem
Инициализируем индекс(CurCh_inNew) который будет считать кол-во символов в новом найденном слове
Входим цикл, который обходит по символьно строку CurCh, до тех пор пока она не кончится
В случае нахождения разделителя устанавливаем separat = 1
Если данный символ не разделитель
Если separat == 1, то обнуляем его
если кол-во символов в новом слове не равняется 1, то запишем его в массив с помощью add_item.
Установим CurCh_inNew = 0
Очистим CurItem
Добавим текущий символ в CurItem
Если CurItem не пуста, то добавим ее в InputItems
Функция int tokenize(const char *s, Token **tokens, int *len):
Принимает строку(s) и преобразует ее в массив (**tokens).
Инициализируем структуру ItemsArray для хранения слов выделенных из строки
С помощью GetItems получим в структуру ItemsArray слова
Инициализируем массив токенов
Входим в цикл обходящий все слова в ItemsArray
Устанавливаем указатель на теще слово
Выделяем память под новый токен
Устанавливаем указатель на текущий токен
Условие: если в слове один символ и первый символ в слове == + или – или * или / ( или ) то
Записать в структуру Token что текущий символ является оператором (tt_OPER)
Сохранить слово в Token
Если нет, то
Заводим индекс CurChar = 1
Если первый символ в слове является числом
Входим в цикл читающий посимвольно слово, до конца
Условие: если текущий символ не является числом,то
Освободить память ItemsArray
Выйти с кодом ошибки -1
Записать в структуру Token что текущий символ является числом (tt_CONST)
Преобразовать слово в число и сохранить в Token
Если нет, то проверяем является ли текущий символ алфавитным. Если да, то
Входим в цикл читающий посимвольно слово, до конца
Условие если текущий символ не алфавитный и не является числом, то
Освободить память ItemsArray
Выйти с кодом ошибки -1
Записать в структуру Token что текущий символ является переменной (tt_ID)
Сохранить слово в Token
Если нет, то
Освободить память ItemsArray
Выйти с кодом ошибки -1
Освободить память ItemsArray
Структура TokensDArray:
Состоит из двух элементов: динамического массива токенов (*items) и переменной (count), в которую записывается количество токенов в стеке.
Функция short push(TokensDArray *stack, const Token *token):
Выделяет память под новый элемент стека и кладет токен(*token) в конец.
Функция short pop(TokensDArray *stack, Token **TokensArray, int *len):
Вынимает токен из конца стека и возвращает его.
Функция short out_UntilBrac(TokensDArray *stack, Token **TokensArray, int *len):
Вынимает последний токен из стека(*stack) и записывает его в массив токенов(**TokensArray).
Выполнение таких операции продолжается до нахождения открывающей строчки.
Функция int infix2postfix(const Token *infix, int in_len, Token **postfix, int *out_len):
Преобразование массива с инфиксной формой(*infix)в массив с постфиксной формой(**postfix).
Инициализируем массив токенов
Инициализируем структуру для стека
Инициализируем массив стека
Входим в цикл, проходящий по всем токенам в массиве с инфиксной формой
Условие. Если текущий токен является оператором, то
Если текущий токен == (, то поместить токен в стек с помощью push
Если текущий токен == ), то вывести все до открывающей скобки в выходную последовательность с помощью out_UntilBrac
Если ни «(» ни «)», то
Если токен == «+» или «-»,то
Входим в цикл, выполняющийся до тех пор пока текущий токен == «+» или «-» или «*» или «/»
Вынимаем токен из стека в выходную последовательность
Помещаем токен в стек
Если нет, то если токен == «*» или «/»
Входим в цикл, выполняющийся до тех пор пока текущий токен == «*» или «/»
Вынимаем токен из стека в выходную последовательность
Помещаем токен в стек
Если нет, то выходим с кодом ошибки -1
Если нет, то если текущий токен является числом или перемнной, то
Выделяем память под новый токен в массиве с постфиксной формой
Записываем теущий токен из массиво с инфиксной формой в массив с постфиксной
Если нет, то выходим с кодом ошибки -2
Выводим все оставшиеся токены в стеке в массив с постфиксной формой с помощью out_everyth
Освобождаем память из под стека