I want to create a kind of parser of the form:
#include <iostream>
#include <string>
#include <sstream>
#include <cctype>
using namespace std;
bool isValid(istringstream& is)
{
char ch;
is.get(ch); //I know get(ch) is a good start but this is as for as I got :)
.......
....
}
int main()
{
string s;
while(getline(cin,s))
{
istringstream is(s);
cout<<(isValid(is)? "Expression OK" : "Not OK")<<endl;
}
}
A boolean function that returns TRUE if the sequence of char is of the form “5” or “(5+3)” or “((5+3)+6)” or “(((4+2)+1)+6)” …etc and FALSE for any other case
Basically, an expression will be considered as valid if it is either a single digit or of the form “open parenthesis-single digit-plus sign-single digit-close parenthesis”
-
Valid Expression = single digit
and
-
Valid Expression = (Valid Expression + Valid Expression)
Given that there is no limit to the size of the above form (number of opening and closing parenthesis..etc.) I’d like to do that using recursion
Being the newbie that I am.. Thank you for any helpful input!
To do a recursive solution you’re gonna want to read the string into a buffer first, then do something like this:
Basically, the expression function returns the length of the valid expression at it’s argument. If it’s argument begins with a parenthesis, it gets the length of the expression after that, verifies the plus after that, then verifies the closing parenthesis after the next expression. If the argument begins with a number, return 1. If something is messed up, return -1. Then using that function we can figure out whether or not the string is valid by some sums and the length of the string.
I haven’t tested the function at all, but the only case this might fail in that I can think of would be excessive parenthesis: ((5)) for example.
An alternative to recursion could be some sort of lexical parsing such as this:
That function’s not complete at all, but you should be able to see where it’s going. I think the recursion works better in this case anyways.