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

相关推荐
py有趣14 分钟前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers33 分钟前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
workflower2 小时前
机器人应用-楼宇室内巡逻
大数据·人工智能·算法·microsoft·机器人·动态规划·享元模式
ZPC82102 小时前
fanuc 机器人通过PR寄存器实现轨迹控制
人工智能·算法·计算机视觉·机器人
py有趣2 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode
Wave8453 小时前
C++继承详解
开发语言·c++·算法
睡觉就不困鸭3 小时前
第9天 两数之和
算法·哈希算法·散列表
贾斯汀玛尔斯3 小时前
每天学一个算法--动态规划(Dynamic Programming, DP)
算法·动态规划
水木流年追梦3 小时前
CodeTop 热门题目汇总hot300题
算法·leetcode·职场和发展
小糖学代码3 小时前
LLM系列:2.pytorch入门:3.基本优化思想与最小二乘法
人工智能·python·算法·机器学习·ai·数据挖掘·最小二乘法