Question

Hello, please correct the following C++ CODE it is not working on visual studio: (I WILL RATE, NO...

Hello, please correct the following C++ CODE it is not working on visual studio: (I WILL RATE, NO INCOMPLETE OR WRONG SOLUTIONS PLEASE)

// CPP program to evaluate a given
// expression where tokens are
// separated by space.
#include
using namespace std;

// Function to find precedence of
// operators.
int precedence(char op){
if(op == '+'||op == '-')
return 1;
if(op == '*'||op == '/')
return 2;
return 0;
}

// Function to perform arithmetic operations.
int applyOp(int a, int b, char op){
switch(op){
case '+': return a + b;
case '-': return a - b;
case '*': return a * b;
}
}

// Function that returns value of
// expression after evaluation.
int evaluate(string tokens){
int i;
  
// stack to store integer values.
stack values;
  
// stack to store operators.
stack ops;
  
for(i = 0; i < tokens.length(); i++){
  
// Current token is a whitespace,
// skip it.
if(tokens[i] == ' ')
continue;
  
// Current token is an opening
// brace, push it to 'ops'
else if(tokens[i] == '('){
ops.push(tokens[i]);
}
  
// Current token is a number, push
// it to stack for numbers.
else if(isdigit(tokens[i])){
int val = 0;
  
// There may be more than one
// digits in number.
while(i < tokens.length() &&
isdigit(tokens[i]))
{
val = (val*10) + (tokens[i]-'0');
i++;
}
  
values.push(val);
}
  
// Closing brace encountered, solve
// entire brace.
else if(tokens[i] == ')')
{
while(!ops.empty() && ops.top() != '(')
{
int val2 = values.top();
values.pop();
  
int val1 = values.top();
values.pop();
  
char op = ops.top();
ops.pop();
  
values.push(applyOp(val1, val2, op));
}
  
// pop opening brace.
ops.pop();
}
  
// Current token is an operator.
else
{
// While top of 'ops' has same or greater
// precedence to current token, which
// is an operator. Apply operator on top
// of 'ops' to top two elements in values stack.
while(!ops.empty() && precedence(ops.top())
>= precedence(tokens[i])){
int val2 = values.top();
values.pop();
  
int val1 = values.top();
values.pop();
  
char op = ops.top();
ops.pop();
  
values.push(applyOp(val1, val2, op));
}
  
// Push current token to 'ops'.
ops.push(tokens[i]);
}
}
  
// Entire expression has been parsed at this
// point, apply remaining ops to remaining
// values.
while(!ops.empty()){
int val2 = values.top();
values.pop();
  
int val1 = values.top();
values.pop();
  
char op = ops.top();
ops.pop();
  
values.push(applyOp(val1, val2, op));
}
  
// Top of 'values' contains result, return it.
return (values.top())%3;
}

int main() {
cout << evaluate("10 + 2 * 6") << "\n";
cout << evaluate("100 * 2 + 12") << "\n";
cout << evaluate("100 * ( 2 + 12 )") << "\n";
cout << evaluate("100 * ( 2 + 12 ) / 14");
return 0;
}

THANK YOU.

0 0
Add a comment Improve this question Transcribed image text
Answer #1

main.cpp

#include <bits/stdc++.h>

using namespace std;

// Function to find precedence of

// operators.

int precedence(char op){

if(op == '+'||op == '-')

return 1;

if(op == '*'||op == '/')

return 2;

return 0;

}

// Function to perform arithmetic operations.

int applyOp(int a, int b, char op){

switch(op){

case '+': return a + b;

case '-': return a - b;

case '*': return a * b;

case '/': return a / b;

}

}

// Function that returns value of

// expression after evaluation.

int evaluate(string tokens){

int i;

// stack to store integer values.

stack <int> values;

// stack to store operators.

stack <char> ops;

for(i = 0; i < tokens.length(); i++){

// Current token is a whitespace,

// skip it.

if(tokens[i] == ' ')

continue;

// Current token is an opening

// brace, push it to 'ops'

else if(tokens[i] == '('){

ops.push(tokens[i]);

}

// Current token is a number, push

// it to stack for numbers.

else if(isdigit(tokens[i])){

int val = 0;

// There may be more than one

// digits in number.

while(i < tokens.length() &&

isdigit(tokens[i]))

{

val = (val*10) + (tokens[i]-'0');

i++;

}

values.push(val);

}

// Closing brace encountered, solve

// entire brace.

else if(tokens[i] == ')')

{

while(!ops.empty() && ops.top() != '(')

{

int val2 = values.top();

values.pop();

int val1 = values.top();

values.pop();

char op = ops.top();

ops.pop();

values.push(applyOp(val1, val2, op));

}

// pop opening brace.

ops.pop();

}

// Current token is an operator.

else

{

// While top of 'ops' has same or greater

// precedence to current token, which

// is an operator. Apply operator on top

// of 'ops' to top two elements in values stack.

while(!ops.empty() && precedence(ops.top())

>= precedence(tokens[i])){

int val2 = values.top();

values.pop();

int val1 = values.top();

values.pop();

char op = ops.top();

ops.pop();

values.push(applyOp(val1, val2, op));

}

// Push current token to 'ops'.

ops.push(tokens[i]);

}

}

// Entire expression has been parsed at this

// point, apply remaining ops to remaining

// values.

while(!ops.empty()){

int val2 = values.top();

values.pop();

int val1 = values.top();

values.pop();

char op = ops.top();

ops.pop();

values.push(applyOp(val1, val2, op));

}

// Top of 'values' contains result, return it.

return values.top();

}

int main() {

cout<<endl;

cout << evaluate("10 + 2 * 6") << "\n";

cout << evaluate("100 * 2 + 12") << "\n";

cout << evaluate("100 * ( 2 + 12 )") << "\n";

cout << evaluate("100 * ( 2 + 12 ) / 14");

return 0;

}

Output:

media%2F0d1%2F0d107714-c8ce-4999-8a4f-6d

Add a comment
Know the answer?
Add Answer to:
Hello, please correct the following C++ CODE it is not working on visual studio: (I WILL RATE, NO...
Your Answer:

Post as a guest

Your Name:

What's your source?

Earn Coins

Coins can be redeemed for fabulous gifts.

Not the answer you're looking for? Ask your own homework help question. Our experts will answer your question WITHIN MINUTES for Free.
Similar Homework Help Questions
  • Here is the code I have so far. I'm trying to figure out how to implement...

    Here is the code I have so far. I'm trying to figure out how to implement a boolean and use precedence. The 2nd expression should be 14 but it comes out as 28 so I'm definitely not understanding. #include <stack> #include <iostream> #include <string> using namespace std; // Function to find precedence of // operators. int precedence(char op) {    if (op == '+' || op == '-')        return 1;    if (op == '*' || op ==...

  • The code below accepts and evaluates an integer expression with the following operators: +, _, *,...

    The code below accepts and evaluates an integer expression with the following operators: +, _, *, and /. Your task is to modify it to include the % remainder operator that has the same precedence as * and /. No need to rewrite the entire program, just insert the needed statements. import java.util.Stack; public class EvaluateExpression { public static void main(String[] args) {     // Check number of arguments passed     if (args.length != 1) {       System.out.println(         "Usage:...

  • Im writing a method to evaluate a postfix expression. Using my own stack class. Here is my code but I keep getting a classcastexception where it says java.lang.Character cannot be cast to java.lang,In...

    Im writing a method to evaluate a postfix expression. Using my own stack class. Here is my code but I keep getting a classcastexception where it says java.lang.Character cannot be cast to java.lang,Integer. Im not sure how to fix this. public class Evaluator { public static void evaluatePost(String postFix)    {        LinkedStack stack2 = new LinkedStack();        int val1;        int val2;        int result;        for(int i = 0; i < postFix.length(); i++)        {            char m = postFix.charAt(i);            if(Character.isDigit(m))            {                stack2.push(m);            }            else            {               ...

  • i want similar for this code to solve two questions : 1- Write a program to...

    i want similar for this code to solve two questions : 1- Write a program to convert a postfix expression to infix expression 2-Write a program to convert an infix expression to prefix expression each question in separate code ( so will be two codes ) #include <iostream> #include <string> #define SIZE 50 using namespace std; // structure to represent a stack struct Stack {   char s[SIZE];   int top; }; void push(Stack *st, char c) {   st->top++;   st->s[st->top] = c;...

  • Infix Expression Evaluator For this project, write a C program that will evaluate an infix expression. The algorithm REQ...

    Infix Expression Evaluator For this project, write a C program that will evaluate an infix expression. The algorithm REQUIRED for this program will use two stacks, an operator stack and a value stack. Both stacks MUST be implemented using a linked list. For this program, you are to write functions for the linked list stacks with the following names: int isEmpty (stack); void push (stack, data); data top (stack); void pop (stack); // return TRUE if the stack has no...

  • Infix Expression Evaluator For this project, write a C program that will evaluate an infix expression. The algorithm REQ...

    Infix Expression Evaluator For this project, write a C program that will evaluate an infix expression. The algorithm REQUIRED for this program will use two stacks, an operator stack and a value stack. Both stacks MUST be implemented using a linked list. For this program, you are to write functions for the linked list stacks with the following names: int isEmpty (stack); void push (stack, data); data top (stack); void pop (stack); // return TRUE if the stack has no...

  • C++ Please ensure code is fully working, will rate Question to be answered:    Repeat Exercise...

    C++ Please ensure code is fully working, will rate Question to be answered:    Repeat Exercise 1 for the class linkedStackType question one:        Two stacks of the same type are the same if they have the same number of elements and their elements at the corresponding positions are the same. Overload the relational operator == for the class stackType that returns true if two stacks of the same type are the same, false otherwise. Also, write the definition...

  • I need assistance with this code. Is there any way I can create this stack class (dealing with infix to postfix then postfix evaluation) without utilizing <stdio.h> and <math.h>? ________...

    I need assistance with this code. Is there any way I can create this stack class (dealing with infix to postfix then postfix evaluation) without utilizing <stdio.h> and <math.h>? ____________________________________________________________________________________________ C++ Program: #include <iostream> #include <string> #include <stdio.h> #include <math.h> using namespace std; //Stack class class STACK { private: char *str; int N; public: //Constructor STACK(int maxN) { str = new char[maxN]; N = -1; } //Function that checks for empty int empty() { return (N == -1); } //Push...

  • This code in C converts infix to postfix and evaluates it. The problem is that it...

    This code in C converts infix to postfix and evaluates it. The problem is that it only evaluates one digit expressions. I need to fix it so that it can evaluate 2 digits expressions as well. #include <stdio.h> #include <ctype.h> #include <string.h> #include <math.h> #define SIZE 100 char s[SIZE]; int top=-1; void infixToPostfix(char *infix, char *postfix); void postfixEvaluation(char *postfix); void push(char elem){ s[++top]=elem; } char pop(){ return(s[top--]); } int pr(char elem){ // Order of precedence switch (elem) { case '(':...

  • HI USING C++ CAN YOU PLEASE PROGRAM THIS ASSIGNMENT AND ADD COMMENTS: stackARRAY: #include<iostream> #define SIZE...

    HI USING C++ CAN YOU PLEASE PROGRAM THIS ASSIGNMENT AND ADD COMMENTS: stackARRAY: #include<iostream> #define SIZE 100 #define NO_ELEMENT -999999 using namespace std; class Stack { int arr[SIZE]; // array to store Stack elements int top; public: Stack() { top = -1; } void push(int); // push an element into Stack int pop(); // pop the top element from Stack int topElement(); // get the top element void display(); // display Stack elements from top to bottom }; void Stack...

ADVERTISEMENT
Free Homework Help App
Download From Google Play
Scan Your Homework
to Get Instant Free Answers
Need Online Homework Help?
Ask a Question
Get Answers For Free
Most questions answered within 3 hours.
ADVERTISEMENT
ADVERTISEMENT
ADVERTISEMENT