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

相关推荐
啊阿狸不会拉杆30 分钟前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
小学生的信奥之路1 小时前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗2 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者3 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy4 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub4 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10074 小时前
08.18总结
算法·深度优先·图论
逆向菜鸟4 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB5 小时前
DolphinDB 回测插件快速上手
算法
利刃大大5 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题