2024-10-07 12:38:16 +00:00
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
#define STACK_SIZE 10 // Максимальный размер стека
|
2024-10-07 12:38:16 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
double stack[STACK_SIZE]; // Массив для стека
|
|
|
|
|
int top = 0; // Индекс верхнего элемента стека
|
2024-10-17 12:02:05 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Функция для вывода элементов стека
|
2024-10-17 12:19:39 +00:00
|
|
|
|
void print_stack() {
|
|
|
|
|
for (int i = 0; i < top; i++) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("%.2f ", stack[i]); // Выводим значение с двумя знаками после запятой
|
2024-10-17 12:19:39 +00:00
|
|
|
|
}
|
|
|
|
|
printf("\n");
|
2024-10-17 11:38:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Функция для добавления элемента в стек
|
2024-10-17 12:19:39 +00:00
|
|
|
|
int push(double value) {
|
|
|
|
|
if (top >= STACK_SIZE) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("full stack\n"); // Стек переполнен
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2024-10-21 11:42:21 +00:00
|
|
|
|
stack[top++] = value; // Добавляем элемент в стек
|
|
|
|
|
print_stack(); // Выводим текущий стек
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 1;
|
2024-10-17 11:38:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Функция для извлечения элемента из стека
|
2024-10-17 12:19:39 +00:00
|
|
|
|
int pop(double *value) {
|
|
|
|
|
if (top <= 0) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("not enough operands\n"); // Недостаточно операндов
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2024-10-21 11:42:21 +00:00
|
|
|
|
*value = stack[--top]; // Извлекаем верхний элемент
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 1;
|
2024-10-17 11:38:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Функция для применения операции к двум верхним элементам стека
|
2024-10-17 12:19:39 +00:00
|
|
|
|
int apply_operation(char op) {
|
|
|
|
|
double a, b;
|
2024-10-17 12:02:05 +00:00
|
|
|
|
|
2024-10-17 12:19:39 +00:00
|
|
|
|
if (!pop(&b) || !pop(&a)) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
return 0; // Если не удалось извлечь операнды, возвращаем 0
|
2024-10-17 11:38:16 +00:00
|
|
|
|
}
|
2024-10-07 12:38:16 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
double result; // Переменная для хранения результата
|
2024-10-17 12:19:39 +00:00
|
|
|
|
switch (op) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
case '+': result = a + b; break; // Сложение
|
|
|
|
|
case '-': result = a - b; break; // Вычитание
|
|
|
|
|
case '*': result = a * b; break; // Умножение
|
2024-10-17 12:19:39 +00:00
|
|
|
|
case '/':
|
|
|
|
|
if (b == 0) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("division by zero\n"); // Деление на ноль
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2024-10-21 11:42:21 +00:00
|
|
|
|
result = a / b; // Деление
|
2024-10-17 12:19:39 +00:00
|
|
|
|
break;
|
|
|
|
|
default:
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("bad input\n"); // Некорректный ввод операции
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2024-10-17 12:02:05 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
return push(result); // Добавляем результат в стек
|
2024-10-17 11:58:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Главная функция
|
2024-10-07 12:38:16 +00:00
|
|
|
|
int main() {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
char input[100]; // Буфер для ввода
|
2024-10-07 12:38:16 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
while (scanf("%s", input) == 1) { // Чтение ввода
|
2024-10-17 12:19:39 +00:00
|
|
|
|
char *end;
|
2024-10-21 11:42:21 +00:00
|
|
|
|
double value = strtod(input, &end); // Преобразование строки в число
|
2024-10-17 11:20:43 +00:00
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Если вся строка была преобразована в число
|
2024-10-17 12:19:39 +00:00
|
|
|
|
if (*end == '\0') {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
if (!push(value)) return 0; // Добавляем значение в стек
|
2024-10-17 12:19:39 +00:00
|
|
|
|
} else if (input[1] == '\0' && strchr("+-*/", input[0])) {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
// Если это одна из операций
|
|
|
|
|
if (!apply_operation(input[0])) return 0; // Применяем операцию
|
2024-10-17 12:07:00 +00:00
|
|
|
|
} else {
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("bad input\n"); // Некорректный ввод
|
2024-10-17 12:19:39 +00:00
|
|
|
|
return 0;
|
2024-10-17 12:07:00 +00:00
|
|
|
|
}
|
2024-10-17 11:41:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-21 11:42:21 +00:00
|
|
|
|
printf("no input\n"); // Если нет ввода
|
2024-10-07 12:38:16 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|