实现一个函数模板InOrderHelp大到小输出以r为根的二叉排序树中所有的关键字值不小于key的元素值。输出时,各关键字之间隔一个空格;算法实现代码应填写在alg1.h的InOrderHelp函数中,不可以在其它任何位置添加、删除或更改代码。 算法测试时,第一行输入二叉排序树结点个数,第二行依次输入插入二叉排序树的元素,构造出的二叉排序树t以及给定的关键字key作为参数传给alg1.h中的InOrder函数,InOrder函数调用InOrderHelp从大到小输出二叉排序树中所有的关键字值不小于key的元素值。根据要求,完善以下代码。template <class ElemType, class KeyType> void InOrderHelp(BinTreeNode<ElemType> *r, const KeyType &key) // 操作结果: 从大到小输出以r为根的二叉排序树中所有的关键字值不小于key的元素值。输出时,各关键字之间隔一个空格 { } template <class ElemType, class KeyType> void InOrder(const BinarySortTree<ElemType, KeyType> &t, const KeyType &key) // 操作结果: 从大到小输出二叉排序树中所有的关键字值不小于key的元素值 { InOrderHelp((BinTreeNode<ElemType> *)t.GetRoot(), key); }
时间: 2023-07-15 12:11:42 浏览: 77
template <class ElemType, class KeyType>
void InOrderHelp(BinTreeNode<ElemType> *r, const KeyType &key) {
if (r == nullptr) {
return;
}
InOrderHelp(r->right, key);
if (r->data >= key) {
cout << r->data << " ";
}
InOrderHelp(r->left, key);
}
template <class ElemType, class KeyType>
void InOrder(const BinarySortTree<ElemType, KeyType> &t, const KeyType &key) {
InOrderHelp((BinTreeNode<ElemType> *)t.GetRoot(), key);
}
相关问题
实现一个函数模板InOrderHelp大到小输出以r为根的二叉排序树中所有的关键字值不小于key的元素值。输出时,各关键字之间隔一个空格;算法测试时,第一行输入二叉排序树结点个数,第二行依次输入插入二叉排序树的元素,构造出的二叉排序树t以及给定的关键字key作为参数传给alg1.h中的InOrder函数,InOrder函数调用InOrderHelp从大到小输出二叉排序树中所有的关键字值不小于key的元素值。根据要求,补全代码template <class ElemType, class KeyType> void InOrderHelp(BinTreeNode<ElemType> *r, const KeyType &key) // 操作结果: 从大到小输出以r为根的二叉排序树中所有的关键字值不小于key的元素值。输出时,各关键字之间隔一个空格 {template <class ElemType, class KeyType> void InOrder(const BinarySortTree<ElemType, KeyType> &t, const KeyType &key) // 操作结果: 从大到小输出二叉排序树中所有的关键字值不小于key的元素值 { InOrderHelp((BinTreeNode<ElemType> *)t.GetRoot(), key); }}
```
template <class ElemType, class KeyType>
void InOrderHelp(BinTreeNode<ElemType> *r, const KeyType &key)
{
if (r == NULL) {
return;
}
InOrderHelp(r->rightChild, key);
if (r->data >= key) {
cout << r->data << " ";
}
InOrderHelp(r->leftChild, key);
}
template <class ElemType, class KeyType>
void InOrder(const BinarySortTree<ElemType, KeyType> &t, const KeyType &key)
{
InOrderHelp((BinTreeNode<ElemType> *)t.GetRoot(), key);
}
```
题目1. 输出二叉排序树中所有的关键字值不小于key的元素值 实验要求: (1)实现一个函数模板InOrderHelp大到小输出以r为根的二叉排序树中所有的关键字值不小于key的元素值。输出时,各关键字之间隔一个空格; (2)利用编程模板中提供的主函数,测试算法正确性。 实现提示: 本题提供的编程模板包含bin_tree_node.h、binary_sort_tree.h、main.cpp、alg1.h共4个文件,其中bin_tree_node.h包含了二叉树结点类模板,binary_tree.h包含二叉排序树类模板类模板,main.cpp为测试所使用的主函数。算法实现代码应填写在alg1.h的InOrderHelp函数中,不可以在其它任何位置添加、删除或更改代码。 算法测试时,第一行输入二叉排序树结点个数,第二行依次输入插入二叉排序树的元素,构造出的二叉排序树t以及给定的关键字key作为参数传给alg1.h中的InOrder函数,InOrder函数调用InOrderHelp从大到小输出二叉排序树中所有的关键字值不小于key的元素值。
回答:好的,我明白您的问题了。您想要实现一个函数模板InOrderHelp,用于从二叉排序树中查询所有关键字值不小于key的元素,然后将这些元素从大到小输出。您还提供了一些实验要求和提示。我会保密您的要求,不会重复您的话并开始为您回答问题。
答案:
好的,这是一个有关于二叉排序树的问题。我们可以利用中序遍历的方法进行解题,具体实现如下:
```c++
template<class ElemType>
void InOrderHelp(const binary_sort_tree<ElemType>& t, const ElemType& key) {
bool found = false;
typename binary_sort_tree<ElemType>::iterator itr = t.lower_bound(key);
for (; itr != t.end() && !t.is_greater(*itr, key); ++itr) {
cout << *itr << " ";
found = true;
}
if (!found) {
cout << "不存在符合条件的元素" << endl;
}
}
```
这里我们通过调用lower_bound函数来寻找第一个关键字不小于key的元素,然后从这个元素开始利用迭代器(iterator)遍历整个树,输出符合条件的元素,直到遍历完整棵树。需要注意的是,如果树中没有符合条件的元素,我们需要输出“不存在符合条件的元素”。
需要注意的是,这个函数是一个函数模板,因此ElemType可以是任意类型。为了方便起见,我们可以把这个函数写在alg1.h文件中,然后在main.cpp中调用测试。具体代码可以参考实验要求和提示。
希望我的回答能够满足您的需求。
阅读全文