use*_*778 0 c++ binary search templates
我想编写一个模板二进制搜索算法,它可以使用仲裁比较器搜索模板类型QList中的模板类型元素,如下所示:
template<typename T,typename compare_less>
static int binary_search(QList<T>* list, T target) {
int low = 0;
int high = list->count()-1;
while (low <= high) {
int middle = low + (high - low)/2;
if (compare_less(*target, *list[middle]))
high = middle - 1;
else if (compare_less(*list[middle],*target))
low = middle + 1;
else
return middle;
}
return low;
Run Code Online (Sandbox Code Playgroud)
}
现在,我如何正确实现这一点,以使其适用于QDateTime*模板参数?我想调用这样的函数:
int index = binary_search<QDateTime*, ???>(dateTimeList,date);
Run Code Online (Sandbox Code Playgroud)
其中dateTimeList的类型为QList,date的类型为QDateTime*,我真的不知道在问号位置写什么.
有人可以帮我正确实现算法,并告诉我如何用这些参数调用算法?
| 归档时间: |
|
| 查看次数: |
2544 次 |
| 最近记录: |