Rumah > pembangunan bahagian belakang > C++ > Gabungkan pokok isihan dalam C++

Gabungkan pokok isihan dalam C++

王林
Lepaskan: 2023-09-12 17:33:03
ke hadapan
1321 orang telah melayarinya

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.

Mari kita fahami dengan contoh

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循环,将数据从数组推送到向量中。# 🎜🎜#

对给定的向量进行排序。创建一个整数类型的向玏。 🎜#
  • #🎜🎜 #调用函数generateTree(1, 0, saiz - 1, vec, tree),并将getSmallestIndex设置为queryWrapper(2, 5, 2, size, vec, tree)。

    #🎜🎜🎜🎜🎜🎜🎜 input 🎜 #

  • 在函数generateTree(int treeIndex, int leftIndex, int rightIndex, vektor > &a, vektor🎜郜)) #

  • 检查JIKA kiriIndeks ke kananIndeks,然后设置 tree[treeIndex].push_back(a[leftIndex].second) dan kembali
  • Tetapkan midValue kepada (leftIndex + rightIndex) / 2dan panggil generateTree(2 * treeIndex, leftIndex , midValue, a, tree), generateTree(2 * treeIndex + 1, midValue + 1, rightIndex, a, tree) dan merge(tree[2 * treeIndex].begin(), tree[2 * treeIndex].end() , tree[2 * treeIndex + 1].mulakan(). Tetapkan tree[2 * treeIndex + 1].end(),back_inserter(tree[treeIndex]))
  • #🎜 🎜#
  • Di dalam fungsi sebagai int countKSmallest(int startIndex, int endIndex, int queryStart, int queryEnd, int treeIndex, int key, vector tree[])

    #🎜🎜 🎜#
  • Semak JIKA startIndex kepada endIndex kemudian kembalikan tree[treeIndex][0]
    • Tetapkan pertengahan kepada (startIndex + endIndex) / 2, last_index upper_bound(tree[2 * treeIndex].begin(),tree[2 * treeIndex].end(), queryEnd) - tree[2 * treeIndex].begin())
    • tetapkan first_in_query_range kepada (lower_bound(tree[2 * treeIndex].begin(),tree[2 * treeIndex].end(), queryStart) - tree[2 * treeIndex].begin()) dan M ke last_in_query_range - first_in_query_range
    • Semak JIKA M lebih besar daripada sama dengan kunci kemudian kembalikan hitungKSmallest(startIndex, mid, queryStart, queryEnd, 2 * treeIndex, key, tree)#🎜
  • ELSE, kemudian kembalikan countKSmallest(mid + 1, endIndex, queryStart, queryEnd, 2 * treeIndex + 1, key - M, tree).

    # 🎜🎜#
    • Di dalam fungsi int queryWrapper(int queryStart, int queryEnd, int key, int n, vector > &a, vectortree[])

    • kembali panggilan ke fungsi countKSmallest(0, n - 1, queryStart - 1, queryEnd - 1, 1, key , pokok)

    • Contoh
    • #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;
      }
      Salin selepas log masuk

      输出

    • Contoh
    • rreee

      输出#🎜从出#🎜🎜🎜运行上述代码,将会生成以下输出

      Count of number which are smaller than or equal to key value in the given range are:
      4
      6
      Salin selepas log masuk

Atas ialah kandungan terperinci Gabungkan pokok isihan dalam C++. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:tutorialspoint.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan