I just want to know where am i wrong here:
import java.io.*;
class Tokens{
public static void main(String[] args)
{
//String[] result = "this is a test".split("");
String[] result = "4543 6546 6556".split("");
boolean flag= true;
String num[] = {"0","1","2","3","4","5","6","7","8","9"};
String specialChars[] = {"-","@","#","*"," "};
for (int x=1; x<result.length; x++)
{
for (int y=0; y<num.length; y++)
{
if ((result[x].equals(num[y])))
{
flag = false;
continue;
}
else
{
flag = true;
}
if (flag == true)
break;
}
if (flag == false)
break;
}
System.out.println(flag);
}
}
Asides from the regex suggestion (which is a good one), it would seem to make more sense to deal with arrays of characters rather than single-char Strings.
In particular, the
split("")call (shudder) could/should be replaced bytoCharArray(). This lets you iterate over each individual character, which more clearly indicates your intent, is less prone to bugs as you know you’re treating each character at once, and is more efficient*. Likewise your valid character sets should also be characters.Your logic is pretty strangely expressed; you’re not even referencing the specialChars set at all, and the looping logic once you’ve found a match seems odd. I think this is your bug; the matching seems to be the wrong way round in that if the character matches the first valid char, you set flag to
falseand continue round the current loop; so it will definitely not match the next valid char and hence you break out of the loop with atrueflag. Always.I would have thought something like this would be more intuitive:
This doesn’t take sequences into account (e.g. the strings “——–** ” and “1” would be valid because all individual characters are valid) but then neither does your original code. A regex is better because it lets you specify the pattern, I supply the above snippet as an example of a clearer way of iterating through the characters.
*Yes, premature optimization is the root of all evil, but when better, cleaner code also happens to be faster that’s an extra win for free.