저는 메인에 삽입 검색을 가지고 있으며 이미 BinarySearch 메서드를 호출하여 이미 정렬 된 배열 내의 번호를 검색합니다. 내가 그것을 컴파일하려고하면 여기에 오류가 삽입 정렬 내 주요입니다. 여기 자바 이진 검색이 작동하지 않습니다.
public class test5
{
public static void main(String[] args)
{
// original order or numbers
System.out.println("Original order of numbers:");
int nums[] = {26, 45, 56, 12, 78, 74, 39, 22, 5, 90, 87, 32, 28, 11, 93, 62, 79, 53, 22, 51};
for(int x = 0; x < nums.length; x++){
System.out.print(nums[x] + " ");
}
// local variables
int unsortedValue; // The first unsorted value
int scan; // used to scan the array
int swapCount = 0;
// the other loop steps the index variable through
// each subscript in the array, starting at 1. This
// is because element 0 is considered already sorted.
for(int index = 1; index < nums.length; index++)
{
// The first element outside the sorted subset is
// nums[index]. Store the value of this elementt
// in unsortedValue.
unsortedValue = nums[index];
// Start the scan at the subscript of the first element
// into its proper position within the sorted subset.
scan = index;
// Move the first element outside the sorted subset
// into its proper position within the sorted subset.
while(scan > 0 && nums[scan-1] > unsortedValue)
{
nums[scan] = nums[scan -1];
scan--;
}
// Insert the unsorted value in its proper position
// within the sorted subset.
nums[scan] = unsortedValue;
swapCount++;
}
// print out results of swap and swapCount
System.out.println();
System.out.println("Insertion sort: ");
for(int index = 0; index < nums.length; index++){
System.out.print(nums[index] + " ");
}
System.out.println();
System.out.println("The swap count is: " + swapCount);
BinarySearch(nums);
}
은 이진 검색
public static int BinarySerach(String[] array, String value)
{
Scanner keyboard = new Scanner(System.in);
System.out.print("Enter target: ");
int target = nums.nextInt();
int index = -1;
int left = 0;
int right = nums.length - 1;
int middle;
while(left <= right){
middle = (left + right)/2;
if(nums[middle] == target){
index = middle;
break;
} else if (nums[middle] > target) {
right = middle - 1;
}else{
left = middle + 1;
}
}
if(index == -1){
System.out.println("element not found");
}else{
System.out.println("element found at index " + index);
}
}
} 내가 기호를 찾을 수 있습니다 얻을
오류에 대한 방법입니다.
전체 스택 추적을 게시하십시오. 그 오류는 그 곳에서 자명하다. – torquestomp
흠 스택 추적. 그게 무슨 뜻인지 모르겠다. Jgrasp와 관련이 있습니까? –