我是靠谱客的博主 忧郁白昼,最近开发中收集的这篇文章主要介绍1008 数组元素循环右移问题 (20 分),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

题目链接:1008 数组元素循环右移问题 (20 分)

#include<cstdio>
int main()
{
	int n,m;
	int a[100];
	int count=0;
	scanf("%d%d",&n,&m);
	m=m%n;
	for(int i=0;i<n;i++)
	{
		scanf("%d",&a[i]);
	} 
	for(int i=n-m;i<n;i++)
	{
		printf("%d",a[i]);
		count++;
		if(count<n)printf(" ");
	}
	for(int i=0;i<n-m;i++)
	{
		printf("%d",a[i]);
		count++;
		if(count<n)printf(" ");
	}
	return 0;
}

方法二

#include<iostream>
#include<vector>
#include<algorithm> 
using namespace std;
int main()
{
	int n,m;
	cin>>n>>m;
	vector<int>a;//c++中的STL 
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	m%=n;
	if(m!=0)
	{
		reverse(begin(a),begin(a)+n);//整个数组逆转 
		reverse(begin(a),begin(a)+m);//数组从a[0]到a[m-1]逆转 ,逆转前m个数 
		reverse(begin(a)+m,begin(a)+n);//数组从a[m-1]到a[n-1]逆转 ,逆转后n-m个数 
	}
	for(int i=0;i<n-1;i++)
	{
		cout<<a[i]<<" ";
	}
	cout<<a[n-1];//防止最后多输出一个空格 
	return 0;
}

 

最后

以上就是忧郁白昼为你收集整理的1008 数组元素循环右移问题 (20 分)的全部内容,希望文章能够帮你解决1008 数组元素循环右移问题 (20 分)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部