前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pta 习题集 5-15 数组循环左移

pta 习题集 5-15 数组循环左移

作者头像
ShenduCC
发布2018-04-27 11:45:53
2K0
发布2018-04-27 11:45:53
举报
文章被收录于专栏:算法修养算法修养

本题要求实现一个对数组进行循环左移的简单函数:一个数组aa中存有nn(>0>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向左移mm(≥0≥0)个位置,即将aa中的数据由(a0a1⋯an−1a​0​​a​1​​⋯an−1​​)变换为(am⋯an−1a0a1⋯am−1am​​⋯an−1​​a​0​​a​1​​⋯am−1​​)(最前面的mm个数循环移至最后面的mm个位置)。如果还需要考虑程序移动数据的次数尽量少,要如何设计移动的方法?

输入格式:

输入第1行给出正整数nn(≤100≤100)和整数mm(≥0≥0);第2行给出nn个整数,其间以空格分隔。 

输出格式:

在一行中输出循环左移mm位以后的整数序列,之间用空格分隔,序列结尾不能有多余空格。

输入样例:

代码语言:javascript
复制
8 3
1 2 3 4 5 6 7 8

输出样例:

代码语言:javascript
复制
4 5 6 7 8 1 2 3
代码语言:javascript
复制
#include <iostream>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include <string>
#include <map>

using namespace std;
int n,m;
int a[105];
int main()
{
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
		scanf("%d",&a[i]);
	m%=n;
	int tag=0;
	for(int i=m+1;i<=n;i++)
	{
		tag++;
		if(tag==n)
			printf("%d\n",a[i]);
		else
			printf("%d ",a[i]);
		
	}
	for(int i=1;i<=m;i++)
	{
		tag++;
		if(tag==n)
			printf("%d\n",a[i]);
		else
			printf("%d ",a[i]);
		

	}

	return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-03-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 输入格式:
  • 输出格式:
  • 输入样例:
  • 输出样例:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档