不知道有什么问题,求个位高手解答

硅步小流 2011-01-04 07:49:57
#include <iostream>
#include <string>
using namespace std;

template<typename T>
int indexOfKey(T list[], int low, int high, T key);

template<typename T>
int indexOfKey(T list[], T key, int size);

int main()
{
int list1[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
int index1 = indexOfKey(list1, 2, 10);
cout << "The index of the key is " << index1 << endl;

double list2[10] = {1.2, 2.5, 3.1, 4, 5, 6, 7, 8.1, 9.5};
int index2 = indexOfKey(list2, 8.1, 10);
cout << "The index of the key is " << index2 << endl;

string list3[4] = {"BeiJing", "ShangHai", "HuNan", "ChenZhou"};
int index3 = indexOfKey(list3, "BeiJing", 4);
cout << "The index of the key is " << index3 << endl;

return 0;
}


template<typename T>
int indexOfKey(T list[], int low, int high, T key)
{
int low = 0;
int high = size - 1;

if (low > high)
return -1 - low;
else
{
int mid = (low + high) / 2;
if (key > list[mid])
return indexOfKey(list, mid + 1, high, key);
else
return indexOfKey(list, low, mid + 1, key);
}
}

template<typename T>
int indexOfKey(T list[], T key, int size)
{
int low = 0;
int high = size - 1;
return indexOfKey(list, low, mid + 1, key);
}
...全文
92 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
liuhex 2011-01-06
  • 打赏
  • 举报
回复
13楼正解
苍蝇①号 2011-01-05
  • 打赏
  • 举报
回复
#include <iostream>
#include <string>
using namespace std;

template<typename T>
int indexOfKey(T list[], int low, int high, T key);

template<typename T>
int indexOfKey(T list[], T key, int size);

int main()
{
int list1[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
int index1 = indexOfKey(list1, 2, 10);
cout << "The index of the key is " << index1 << endl;

double list2[10] = {1.2, 2.5, 3.1, 4, 5, 6, 7, 8.1, 9.5};
int index2 = indexOfKey(list2, 8.1, 10);
cout << "The index of the key is " << index2 << endl;

string list3[4] = {"BeiJing", "ShangHai", "HuNan", "ChenZhou"};
int index3 = indexOfKey(list3, string("BeiJing"), 4);
cout << "The index of the key is " << index3 << endl;

return 0;
}


template<typename T>
int indexOfKey(T list[], int low, int high, T key)
{

if (low > high)
return -1 - low;
else
{
int mid = (low + high) / 2;
if (key > list[mid])
return indexOfKey(list, mid, high, key);
else if(key==list[mid]){
return mid;
}
return indexOfKey(list, low, mid, key);
}
}

template<typename T>
int indexOfKey(T list[], T key, int size)
{
int low = 0;
int high = size - 1;
return indexOfKey(list, low, high, key);
}

没有判断相等的情况,导致一直循环下去,死循环,最后导致栈溢出
枫桦沐阳 2011-01-05
  • 打赏
  • 举报
回复
low high 重复定义 size - 1的size从何而来

int indexOfKey(T list[], int low, int high, T key)
{
int low = 0;
int high = size - 1;


mid是什么东西

return indexOfKey(list, low, mid + 1, key);


你的程序逻辑很简单,你把它编译过了基本上就成功了。。
bluesky12312388 2011-01-05
  • 打赏
  • 举报
回复

return indexOfKey(list, low, mid + 1, key);
//mid从何而来?
pstrunner 2011-01-05
  • 打赏
  • 举报
回复
编译应该不过吧。
ligangdili 2011-01-05
  • 打赏
  • 举报
回复
template<typename T>
int indexOfKey(T list[], T key, int size)
{
int low = 0;
int high = size - 1;
return indexOfKey(list, low, mid + 1, key);
}
中的mid从何而来?
碎碎念 2011-01-04
  • 打赏
  • 举报
回复
这个函数定义是...没加参数size...
template<typename T>
int indexOfKey(T list[], int low, int high, T key)//在后面加int size
{
int low = 0;
int high = size - 1;//没有size参数...

if (low > high)
return -1 - low;
else
{
int mid = (low + high) / 2;
if (key > list[mid])
return indexOfKey(list, mid + 1, high, key);
else
return indexOfKey(list, low, mid + 1, key);
}
}
一根烂笔头 2011-01-04
  • 打赏
  • 举报
回复
不是高手,只是游击战士
硅步小流 2011-01-04
  • 打赏
  • 举报
回复
请各位高手随便把QQ留一下
硅步小流 2011-01-04
  • 打赏
  • 举报
回复
我用的是二分法搜索
硅步小流 2011-01-04
  • 打赏
  • 举报
回复
我就是不知道什么问题,所以请各位高手讲详细些
bdmh 2011-01-04
  • 打赏
  • 举报
回复
就是有问题,就是你的查找算法有问题
bdmh 2011-01-04
  • 打赏
  • 举报
回复
神仙越来越多
  • 打赏
  • 举报
回复
老大,你怎么也得贴出错误来吧

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧