0

0

按照给定的查询重新排列和更新数组元素

王林

王林

发布时间:2023-09-14 16:29:09

|

1408人浏览过

|

来源于tutorialspoint

转载

按照给定的查询重新排列和更新数组元素

在这个问题中,我们将对数组元素执行给定的查询。查询包含数组元素的循环左旋转、右旋转和更新。

解决问题的逻辑部分是数组旋转。向左旋转数组的简单方法是将每个元素替换为下一个元素,将最后一个元素替换为第一个元素。

我们可以使用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。

网龙b2b仿阿里巴巴电子商务平台
网龙b2b仿阿里巴巴电子商务平台

本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,

下载

方法 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 
using namespace std;

void performQueries(int arr[], int N, vector> &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> 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 
using namespace std;

void performQueries(int arr[], int N, vector> &queries) {
    // Queue to insert array elements
    deque 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> 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) 时间内执行左右旋转操作。因此,它提高了执行给定查询的代码的效率。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1501

2023.10.24

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

538

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

27

2026.01.06

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

407

2023.08.14

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

167

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

35

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

74

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

2

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

CSS3 教程
CSS3 教程

共18课时 | 5万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号