Rumah > Artikel > pembangunan bahagian belakang > Gabungkan pokok isihan dalam C++
Kami diberi tatasusunan integer, set penunjuk permulaan dan penamat segmen serta nilai utama dan penyataan masalah di sini adalah untuk mencari semua nilai dalam julat yang diberikan yang lebih kecil daripada atau sama dengan nilai kunci yang diberikan.
Input − arr[] = {7, 8 , 1, 4 , 6 , 8 , 10 }
Segmen 1: mula = 2, tamat = 4, k = 2
Segmen 2: mula = 1, tamat = 6, k = 3
Output − Kiraan nombor yang lebih kecil daripada atau sama dengan nilai kunci dalam julat yang diberikan ialah 2 6
#🎜🎜 #Penjelasan − [8, 1, 4] mewakili julat dari 2 hingga 4 dan 2 ialah nombor ke-2 terkecil dalam julat [7, 8 , 1, 4 , 6 , 8 ]代表从1到6的范围,6是范围内第三小的数字#🎜🎜围,6是范围内第三小的数字
#🎜🎜🎜🎜🎜🎜🎜🎗 ] = {2, 7 , 9, 4 , 6 , 5 , 1 |段落1:起始位置=3,结束位置=6,k=4#🎜#🎜🎜段落2:起始位置=2,结束位置=5,k=3
输出- 在给厜中关键值的数字的数量为:9 7
解释 - [9, 4 , 6 , 5]代表从3到6的范围,9是给囏定街 [7 , 9, 4 , 6 ] 表示从2到4的范围,7是给定段范围中第3小的数字
#🎜🎜🎜🎜##🎜🎜下下面如下:# 🎜🎜#声明一个整数类型的数组。计算数组的大小。声明一个向向量数类型的对。开始FOR循环,将数据从数组推送到向量中。# 🎜🎜#
对给定的向量进行排序。创建一个整数类型的向玏。 🎜##🎜🎜🎜🎜🎜🎜🎜 input 🎜 #
Di dalam fungsi int queryWrapper(int queryStart, int queryEnd, int key, int n, vector
kembali panggilan ke fungsi countKSmallest(0, n - 1, queryStart - 1, queryEnd - 1, 1, key , pokok)
#include <bits/stdc++.h> using namespace std; const int MAX = 1000; void generateTree(int treeIndex, int leftIndex, int rightIndex, vector<pair<int, int> > &a, vector<int> tree[]){ if (leftIndex == rightIndex){ tree[treeIndex].push_back(a[leftIndex].second); return; } int midValue = (leftIndex + rightIndex) / 2; generateTree(2 * treeIndex, leftIndex, midValue, a, tree); generateTree(2 * treeIndex + 1, midValue + 1, rightIndex, a, tree); merge(tree[2 * treeIndex].begin(), tree[2 * treeIndex].end(), tree[2 * treeIndex + 1].begin(), tree[2 * treeIndex + 1].end(), back_inserter(tree[treeIndex])); } int calculateKSmallest(int startIndex, int endIndex, int queryStart, int queryEnd, int treeIndex, int key, vector<int> tree[]){ if (startIndex == endIndex){ return tree[treeIndex][0]; } int mid = (startIndex + endIndex) / 2; int last_in_query_range = (upper_bound(tree[2 * treeIndex].begin(), tree[2 * treeIndex].end(), queryEnd) - tree[2 * treeIndex].begin()); int first_in_query_range = (lower_bound(tree[2 * treeIndex].begin(), tree[2 * treeIndex].end(),queryStart) - tree[2 * treeIndex].begin()); int M = last_in_query_range - first_in_query_range; if (M >= key){ return calculateKSmallest(startIndex, mid, queryStart, queryEnd, 2 * treeIndex, key, tree); } else { return calculateKSmallest(mid + 1, endIndex, queryStart,queryEnd, 2 * treeIndex + 1, key - M, tree); } } int queryWrapper(int queryStart, int queryEnd, int key, int n, vector<pair<int, int> > &a, vector<int> tree[]){ return calculateKSmallest(0, n - 1, queryStart - 1, queryEnd - 1, 1, key, tree); } int main(){ int input[] = { 7, 8 , 1, 4 , 6 , 8 , 10 }; int size = sizeof(input)/sizeof(input[0]); vector<pair<int, int> > vec; for (int i = 0; i < size; i++) { vec.push_back(make_pair(input[i], i)); } sort(vec.begin(), vec.end()); vector<int> tree[MAX]; generateTree(1, 0, size - 1, vec, tree); cout<<"Count of number which are smaller than or equal to key value in the given range are:"<<endl; int getSmallestIndex = queryWrapper(2, 4, 2, size, vec, tree); cout << input[getSmallestIndex] << endl; getSmallestIndex = queryWrapper(1, 6, 3, size, vec, tree); cout << input[getSmallestIndex] << endl; return 0; }
输出
输出#🎜从出#🎜🎜🎜运行上述代码,将会生成以下输出
Count of number which are smaller than or equal to key value in the given range are: 4 6
Atas ialah kandungan terperinci Gabungkan pokok isihan dalam C++. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!