I\'m trying to make a polynomial operator (sum, rest, multiplication and division of two or more polynomials). The code must be in Java and using linked lists.
I was
In general, this is solved using parsers - there are many libraries that allow doing this, take a look here. As this is not a complex parsing problem and is a homework, you will probably write all by hand - for that, recursive descent parsers (also called top-down parsers) are the easiest. Also take a look at a similar StackOverflow question.
What you mentioned - splitting by characters, would work pretty well in this case. In general, you want to think in the terms of precedence. You first evaluate ^, then * and /, then + and -. Recursive descent parsers work top-down, so you first divide into things that evaluate last - that is, divide on + and -, then on * and / and finally on ^.
In your example, you start with:
10x^2 - 7x + 9
so you first get three nodes by splitting on + and -:
T1 = 10x^2
T2 = -7x
T3 = +9
This gives you the polynomial terms which are in the form +/- n*x^k:
10x^2 = +10 * x ^ 2
-7x = -7 * x ^ 1
+9 = +9 * x ^ 0
Thus, for each of the above you:
You mentioned validation. I.e. you'd like to discard invalid inputs such as:
1 + 2x^
-- 1 + 4^
x^2^3 + x
A bit more work, you can use regular expressions and their Java implementation for this job. If you use top-down parser as mentioned above, you'd do this on each level. Something like:
Check that each term is of the form: +/- (n, nx or nx^k)
You can use regex such as this (note - I did not test it):
"(\\+?|-)([1-9][0-9])?(x(\^[1-9][0-9])?)?"
which basically says:
Maybe ^digits: (\\^[1-9][0-9]*)?.
If you never used them, take a look at the above docs. Note "\\" are used in Java strings to escape "\" character.
Using regex groups, you can even capture the respective parts easily. You can use regex testers such as this for this to help you out.
A good idea is removing spaces before processing - in fact, that would probably be necessary. Note that if you need to handle negative coefficients and/or parentheses, this gets a bit more complicated then the above, leaning towards the real parsers.
Hope this helps.