【发布时间】:2012-10-20 10:00:10
【问题描述】:
当我运行这个程序并输入一个值来搜索程序崩溃时(exe 已经停止工作,关闭程序)。输入值 65 时,出现无限循环 Number not found Enter a value to search (-1 to quit):
代码如下:
#include <iostream>
using namespace std;
void Search(int[], int * , int * );
int main()
{
int i,KEY,num, array[] = {98,87,76,65,54};
for(i=0;i<5;i++)
cout << array[i] << " ";
Search(array, &KEY, &num);
cout << endl;
system("pause");
return 0;
}
void Search(int arr[5], int * current, int * numel)
{
int low, high,search,N;
cout << "\nWhat Number would you like to search for? (-1 to quit) : ";
cin >> search;
while(search!=-1)
{
low=0;
high=N-1;
while(low<=high)
{
*current=(low+high)/2;
if (search > arr[*current])
low=*current+1;
else if(search<arr[*current])
high=*current-1;
else
break;
}
if(arr[*current]==search)
cout << "Number found at index " << *current << endl;
else
cout << "Number not found." << endl;
cout << "Enter a value to search (-1 to quit) :";
}
return;
}
【问题讨论】:
-
我的问题是为什么我的代码会失败/崩溃?
-
我建议您自己对崩溃进行一些研究。首先使用调试器或插入输出语句来查找崩溃发生的位置。然后从那里向后工作,试图找出问题所在。
-
谢谢,似乎数组值没有被传递给函数和/或如果找不到值,则循环永远不会结束。
-
啊!!数组不是从低到高的顺序。
-
感谢指导,程序运行良好。
标签: c++ arrays search pointers binary