Hey, I created a Math Parser using C. The program is designed to take user input, tokenize it, and evaluate the mathematical expression, then return the output back to the user. The implementation uses the Shunting Yard algorithm for infix to postfix conversion as a way to evaluate the result. It can handle basic arithmetic operations such as addition, subtraction, multiplication, and division, as well as parentheses behavior.
Hope you’d like it!
- Tokenizes mathematical expressions
- Supports basic operations: addition, subtraction, multiplication, division as well as parentheses behavior
- Converts infix expressions to postfix notation
- Evaluates postfix expressions
- Dynamic memory management for arrays
- GCC compiler, Visual Studio, or Visual Studio Code
To build and run the Math Parser, follow these steps:
- Clone the repository:
git clone https://github.com/YourUsername/math_parser.git
- Navigate to the project directory:
cd math_parser
For GCC Compiler
- Compile the source code:
gcc -g main.c tokenization.c stack.c numeric_operations.c -o math_parser
- Run the program::
./math_parser
For Visual Studio/Code
-
Load the math_parser.c source and header files in your IDE.
-
Build and run the program using your IDE's functionality.
Once the Math Parser is running, you can input mathematical expressions directly. You can choose between two modes: Default and Verbose.
in this mode the output will be shown without any process indicators
Enter equation: 3 + 5 * (2 - 8)
Result: -27
this mode will show the parser processing stages such as:
- Input status
- Memory allocation status
- Tokenization status
- Postfix notation
./math_parser -v
Enter equation: 3 + 5 * (2 - 8)
Input reading succeeded
Equation entered: 3 + 5 * (2 - 8)
Memory allocation succeeded for string
Memory allocation succeeded for tokens
Successfully tokenized the string
Postfix notation: 3528-*+
Result: -27
In the future, I'd like to add these features:
-
File Scanning: Enable the parser to read mathematical expressions from a file. This will allow users to input expressions via files instead of using the command line.
-
Print Options: Implement functionality to format and print results in a more user-friendly way. This could include options for displaying expressions with proper notation or saving outputs to a file.
-
Error Handling Enhancements: Improve error detection and user feedback for invalid inputs, helping users understand what went wrong and how to fix it.
-
Extended Functionality: Consider adding support for more advanced mathematical functions, such as algebraic operations.
-
Graphical User Interface (GUI): Find a solution to providing a more user-friendly graphical interface for interaction, rather than relying solely on the command line or IDE.