蓝桥杯练习系统(算法训练)ALGO-979 移动

资源限制

内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

问题描述

给定一个n长的数列,有m次操作,第i次操作表示将整个数列循环移动mi位,询问每次操作结束后的开头k个数字

输入格式

第一行三个整数n,m,k。

第二行n个整数表示数列。

接下来m行,每行一个整数mi,表示移动位数,若mi为正,表示向左移mi位,若mi为负数,表示向右移-mi位。

输出格式

m行,每行k个数,表示开头k个数字

样例输入

5 2 3

1 2 3 4 5

2

-2

样例输出

3 4 5

1 2 3

数据规模和约定

n<=1000000

m<=100000

k<=min(10,n)

mi<=100000000

cpp 复制代码
#include<iostream>
using namespace std;
const int N=10e6+5;
int a[N];
int n,m,k;
void print(int j){
	for(int i=0;i<k;i++){
		cout<<("%d ",a[(j+i)%n])<<" ";
//		printf("%d ",a[(j+i)%n]);
	} 
	cout<<endl;
}
int main(){
	scanf("%d%d%d",&n,&m,&k);
	int j=0;//指针j 
	for(int i=0;i<n;i++){
		scanf("%d",&a[i]);
	}
	while(m--){
		int mi;
		scanf("%d",&mi);
		j=j+mi;//指针变化 
		//防止出界 
		if(j>=n){
			j=j%n;
		}
		if(j<0){
			while(j<0){
				j=j+n;
			}
		}
		print(j);
	}
	return 0;
} 

思路:用指针j指向数组元素,一开始时指针j指向第一个数,因此j=0,向左移动mi,就相当于指针向右移动mi。

//这里有个很奇怪的地方,把print函数里的cout换成printf就运行超时了。。。

相关推荐
颜酱31 分钟前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者16 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮17 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者17 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考17 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx21 小时前
CART决策树基本原理
算法·机器学习
Wect21 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱1 天前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway1 天前
解析残差网络 (ResNet)
算法
拖拉斯旋风1 天前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法