Sorry if this is a repeat, but I've been looking for an answer to this question, but I can't find one anywhere and my last question was for the same code but with a different problem.
I need to find a string inside an array, but all the Strings in the array are 16 characters long and the search key will not be 16 characters when entered by the user. Every attempt I've made at this thus far has ended with the String not being found, though I know it is in the array. I think it has something to do with the trailing spaces after the actual string text in the array, but I'm not sure how to handle it.
This is my search statement so far. I'll note that my compareTo() statement does compare this.name to other.name, so I'm quite confused.:
case 'b':
System.out.println();
System.out.println("Please enter 开发者_StackOverflow中文版a customer name:");
String search = kb.nextLine(); //read the user's search
int place; //location of result
Arrays.sort(A);
Customer searchCust = new Customer(search);
place = Arrays.binarySearch(A,searchCust);
if (place <= 0)
System.out.println("Cannot find customer named " + search);
else
{
System.out.println("Customer found:");
System.out.println(A[place-1]);
break;
public int compareTo(Customer a)
{
return this.name.compareTo(a.name);
} //end compareTo
Edit: after clarification of the question.
So, the problem is that your users are entering something like
"Smith"but your array elements are always padded to 16-characters long and might have the search term somewhere in the middle, like
"John Smith "then I would recommend just looping through the array and doing a
.contains()
on each element.
Binary search is an optimization which I would only consider if performance shows itself to be a problem, because it introduces quite a lot of complication.
Okay, if binary search isn't possible (which seems to be the case), we can just implement a simple custom solution:
public Customer findCustomerByName(Customer[] array, String pattern){
for(Customer candidate: array){
if(candidate.getName().contains(pattern)){
return candidate;
}
}
return null;
}
Or did I miss something?
If your search key is different from your array values your binary search wont find a match using compareTo - if as you say you've implemented it to do a plain old String equality check.
There's another implementation fo binarySearch that takes a custom Comparator object...
public static int binarySearch(Object[] a,
Object key,
Comparator c)
You could implement your own custom Comparator to match the shortened key to the array value.
Or you make your class Customer implement Comparable
(see Comparable). Then you implement int compareTo(Customer otherCustomer)
inside Customer, where you return <0, 0 or >0 number, depending on whether otherCustomer
should be less, equal, greater than this
(the current object).
As taken from Arrays.sort
:
All elements in the array must implement the Comparable interface. Furthermore, all elements in the array must be mutually comparable (that is, e1.compareTo(e2) must not throw a ClassCastException for any elements e1 and e2 in the array).
My notes:
Make sure Customer correctly implements natural ordering (aka Comparable) or;
Use the version of
binarySearch
that takes a Comparator (http://download.oracle.com/javase/6/docs/api/java/util/Arrays.html) and;Verify the input is as expected (e.g. it contains no extra new-line character, etc) and;
Make sure A is of the correct type --
Customer[]
in this case (the declaration is not given).binarySort(string[], Customer)
will never succeed. (If using the version of binarySort that takes a Comparator a mismatch like this would not compile.)
Happy coding.
精彩评论