按照给定的查询重新排列和更新数组元素
在这个问题中,我们将对数组元素执行给定的查询。查询包含数组元素的循环左旋转、右旋转和更新。
解决问题的逻辑部分是数组旋转。向左旋转数组的简单方法是将每个元素替换为下一个元素,将最后一个元素替换为第一个元素。
我们可以使用deque数据结构来高效地旋转数组。
问题陈述 - 我们给出了一个包含整数值的 arr[] 数组。此外,我们还给出了一个包含 K 个查询的 requests[] 数组。我们需要根据以下规则对 arr[] 数组元素执行 requests[] 中给出的每个查询。
{0} - 对数组进行圆形左旋转。
{1) - 对数组进行圆形右旋转。
{2, p, q} - 用 q 更新第 p 个索引处的元素。
{3, p} - 打印第 p 个索引中的元素。
示例
输入
arr[] = {8, 9, 13, 44, 76, 67, 21, 51}; queries = {{1}, {0}, {2, 4, 50}, {3, 2}, {2, 2, 223}, {3, 2}};
输出
13,223
解释- 让我们执行每个查询。
{1} -> 将数组向右旋转后,数组变为 {51, 8, 9, 13, 44, 76, 67, 21}
{0} -> 将更新后的数组向左旋转后,数组变为等于 {8, 9, 13, 44, 76, 67, 21, 51}。
< /里>{2, 4, 50} -> 将索引 4 处的元素更新为 50 后,数组变为 {8, 9, 13, 44, 50, 67, 21, 51}
< /里>{3, 2} -> 它打印第二个索引中的元素。
{2, 2, 223}−> 将第二个索引处的元素更新为 223,数组变为 {8, 9, 223, 44, 50, 67, 21, 51}。 p>
{3, 2} -> 它打印第二个索引中的元素。
输入
arr[] = {3, 2, 1}, {{3, 2}, {3, 0}}
输出
1,3
说明 - 它从第 2 个和第 0 个索引打印数组。
输入
arr[] = {76,20,51,78}, queries={{1},{1},{3, 1}}
输出
78
解释- 将数组向右旋转 2 次后,数组变为 [51, 78, 76, 20]。第一个索引处的元素是 78。
方法 1
在这种方法中,我们将遍历每个查询并根据给定的查询执行操作。我们将数组中的每个元素替换为下一个元素,以将其向左旋转,并将每个元素替换为前一个元素,以将其向右旋转。
算法
第 1 步- 开始遍历每个查询。
步骤 2− 如果查询[p][0]等于 0,请按照以下步骤操作。
步骤 2.1- 使用数组的第一个元素初始化“temp”变量。
步骤 2.2- 开始遍历数组,并将每个元素替换为下一个元素。
步骤 2.3- 将最后一个元素替换为“temp”值。
第 3 步− 如果查询[p][0] 等于 1,请按照以下步骤操作。
步骤 3.1- 将数组的最后一个元素存储在“temp”变量中。
步骤 3.2- 开始遍历数组,并将每个元素替换为前一个元素。
步骤 3.3- 使用“temp”值更新第一个元素。
第 4 步- 如果 requests[p][0] 为 2,则使用给定值更新给定索引处的数组元素。
第 5 步- 如果 requests[p][0] 为 3,则打印给定索引的数组值。
示例
#include <bits/stdc++.h> using namespace std; void performQueries(int arr[], int N, vector<vector<int>> &queries) { int len = queries.size(); for (int p = 0; p < len; p++) { // For left shift if (queries[p][0] == 0) { // left shift array int temp = arr[0]; for (int p = 0; p < N - 1; p++){ arr[p] = arr[p + 1]; } arr[N - 1] = temp; } // For the right shift else if (queries[p][0] == 1) { // Right shift array int temp = arr[N - 1]; for (int p = N - 1; p > 0; p--){ arr[p] = arr[p - 1]; } arr[0] = temp; } // For updating the value else if (queries[p][0] == 2) { arr[queries[p][1]] = queries[p][2]; } // For printing the value else { cout << arr[queries[p][1]] << " "; } } } int main() { int arr[] = {8, 9, 13, 44, 76, 67, 21, 51}; int N = sizeof(arr) / sizeof(arr[0]); vector<vector<int>> queries; queries = {{1}, {0}, {2, 4, 50}, {3, 2}, {2, 2, 223}, {3, 2}}; performQueries(arr, N, queries); return 0; }
输出
13 223
时间复杂度 - O(N*K),遍历查询并旋转数组。
空间复杂度 - O(1),因为我们使用常量空间。
方法2
在这种方法中,我们将使用双端队列来存储数组元素。之后,要向左旋转数组,我们可以从队列中弹出前面的元素并将其推入队列的末尾。同样,我们可以将数组向正确的方向旋转。
算法
第 1 步- 定义双端队列并将所有数组元素推入队列。
步骤 2- 使用 for 循环遍历每个查询。
步骤 3- 要将数组向左旋转,请从队列开头删除第一个元素,并将其推到队列末尾。
第 4 步- 要沿正确方向旋转数组,请从队列末尾删除一个元素,并将该元素推入开头。
第 5 步- 根据给定的查询更新元素或打印元素值。
示例
#include <bits/stdc++.h> using namespace std; void performQueries(int arr[], int N, vector<vector<int>> &queries) { // Queue to insert array elements deque<int> que; // Add elements to queue for (int p = 0; p < N; p++) { que.push_back(arr[p]); } // total queries int len = queries.size(); for (int p = 0; p < len; p++) { // For left shift if (queries[p][0] == 0) { // Get the first element int temp = que[0]; // Remove the first element que.pop_front(); // Push element at the last que.push_back(temp); } // For the right shift else if (queries[p][0] == 1) { // Get the last element int temp = que[N - 1]; // remove the last element que.pop_back(); // Insert element at the start que.push_front(temp); } // For updating the value else if (queries[p][0] == 2) { que[queries[p][1]] = queries[p][2]; } // For printing the value else { cout << que[queries[p][1]] << " "; } } } int main() { int arr[] = {8, 9, 13, 44, 76, 67, 21, 51}; int N = sizeof(arr) / sizeof(arr[0]); vector<vector<int>> queries; queries = {{1}, {0}, {2, 4, 50}, {3, 2}, {2, 2, 223}, {3, 2}}; performQueries(arr, N, queries); return 0; }
输出
13 223
时间复杂度 - 将数组元素插入队列的 O(N+K)。
空间复杂度 - 将元素存储到双端队列中的 O(N)。
双端队列数据结构允许我们在 O(1) 时间内执行左右旋转操作。因此,它提高了执行给定查询的代码的效率。
以上是按照给定的查询重新排列和更新数组元素的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

小伙伴电脑出现这样的故障,打开“此电脑”和C盘文件会提示“Explorer.EXEWindows无法访问指定设备、路径或文件。你可能没有适当的权限访问访问该项目。”包括文件夹、文件、此电脑、回收站等,双击都会弹出这样的窗口,右键打开又是正常的。这是系统更新导致,如果你也遇到这样的情况,下面小编教大家如何解决。一,打开注册表编辑器Win+R,输入regedit,或右键开始菜单运行输入regedit;二,定位注册表“计算机\HKEY_CLASSES_ROOT\PackagedCom\ClassInd

使用foreach循环去除PHP数组中重复元素的方法如下:遍历数组,若元素已存在且当前位置不是第一个出现的位置,则删除它。举例而言,若数据库查询结果存在重复记录,可使用此方法去除,得到不含重复记录的结果。

Windows更新可能导致以下一些问题:1.兼容性问题:某些应用程序、驱动程序或硬件设备可能与新的Windows更新不兼容,导致它们无法正常工作或崩溃。2.性能问题:有时,Windows更新可能会导致系统变得更慢或出现性能下降的情况。这可能是由于新的功能或改进需要更多资源来运行。3.系统稳定性问题:某些用户报告称,在安装Windows更新后,系统可能会出现意外的崩溃或蓝屏错误。4.数据丢失:在罕见的情况下,Windows更新可能会导致数据丢失或文件损坏。这是为什么在进行任何重要的更新之前,备份您

PHP中深度复制数组的方法包括:使用json_decode和json_encode进行JSON编码和解码。使用array_map和clone进行深度复制键和值的副本。使用serialize和unserialize进行序列化和反序列化。

PHP数组键值翻转方法性能对比表明:array_flip()函数在大型数组(超过100万个元素)下比for循环性能更优,耗时更短。手动翻转键值的for循环方法耗时相对较长。

本站5月3日消息,微星公司今天发布了AMDAM4AGESA1.2.0.Ca固件更新,修复了针对AMDRyzen4000系列Zen2APU中的Zenbleed安全漏洞。微星本次发布的固件更新适用于几乎所有X570主板,主要修复了适用于Zen2处理器中CVE-2023-20593,AMD将其归类为中级威胁。本站注:该漏洞追踪编号为CVE-2023-20593,能以每核心每秒30KB的速度窃取机密数据。此攻击会影响CPU上运行的所有软件,包括虚拟机、沙箱、容器和进程。尽管AGESA1.2.0.Ca的目

在PHP中执行数组深度复制的最佳实践是:使用json_decode(json_encode($arr))将数组转换为JSON字符串,然后再将其转换回数组。使用unserialize(serialize($arr))将数组序列化为字符串,然后将其反序列化为新数组。使用RecursiveIteratorIterator迭代器对多维数组进行递归遍历。

PHP的array_group_by函数可根据键或闭包函数对数组中的元素分组,返回一个关联数组,其中键是组名,值是属于该组的元素数组。
