蓝桥杯练习系统(算法训练)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就运行超时了。。。

相关推荐
JieE21215 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架