为了解决一个问题,在这个问题中,我们得到一个包含盒子大小的数组。现在我们得到了一个条件,如果大盒子的大小至少是小盒子的两倍,我们可以把一个小盒子放在一个大盒子里。例如,现在我们必须确定有多少可见框。
Input : arr[] = { 1, 3, 4, 5 } Output : 3 Put a box of size 1 in the box of size 3. Input : arr[] = { 4, 2, 1, 8 } Output : 1
在这个问题中,我们的方法是随着我们的前进现在对我们的数组进行排序。我们现在将元素推入队列。随着我们的进展,我们将查看当前元素是否大于或等于队列前端元素的两倍。如果为真,我们现在弹出前面的元素。最后,我们推送队列中的当前元素。我们的答案将是最终队列的大小。
#include <bits/stdc++.h> using namespace std; int main(){ int arr[] = { 1, 2, 3, 4, 5, 6 }; // 给定包含我们盒子大小的数组 int n = sizeof(arr) / sizeof(arr[0]); // 我们数组的大小 queue<int> q; sort(arr, arr + n); // 排序我们的数组 q.push(arr[0]); // 将最小的元素推到前面 for (int i = 1; i < n; i++) { // 遍历数组 int curr = q.front(); // 当前元素 if (arr[i] >= 2 * curr) // 如果当前框的大小大于两倍 // 前面的盒子,所以我们弹出前面 q.pop(); q.push(arr[i]); // 推送队列中的当前元素 } cout << q.size() << "\n"; // 我们的回答 return 0; }输出结果
3
在本教程中,我们解决了一个问题,即在将一个框放入另一个框后找到可见框的数量。我们还学习了针对此问题的 C++ 程序以及解决此问题的完整方法(Normal)。我们可以用其他语言编写相同的程序,例如 C、java、python 和其他语言。我们希望本教程对您有所帮助。