【PAT乙级】1008 数组元素循环右移问题 (20 分)

在这里插入图片描述
https://pintia.cn/problem-sets/994805260223102976/problems/994805316250615808

方法一: 用一个数组保存移动动后的数组

#include<cstdio>
#include<iostream>
using namespace std;
int a[1000];
int b[1000];
int main(void)
{
	int n,m;
    while(cin>>n>>m)
    {
        for(int i=0;i<n;i++) cin>>a[i];
	    for(int i=0;i<n;i++) b[(i+m)%n]=a[i];
	    for(int i=0;i<n;i++) 
        {
            cout<<b[i];
            if(i!=n-1) cout<<" ";
        }
        cout<<endl;
    }
	return 0;
}

方法二: 用队列模拟

#include<cstdio>
#include<iostream>
#include<queue>
using namespace std;
int main(void)
{
	int n,m; cin>>n>>m;
	deque<int> q;
	for(int i=0;i<n;i++) 
	{
		int number; cin>>number;
		q.push_back(number);
	}
	while(m--)
	{
		int number=q.back();
		q.pop_back();
		q.push_front(number);
	}
	while(q.size()>1) cout<<q.front()<<" ",q.pop_front();
	cout<<q.front();
	return 0;
}
#include<cstdio>
#include<iostream>
#include<queue>
using namespace std;
deque<int> q;
int n,m;
int main(void)
{
	cin>>n>>m;
	for(int i=0;i<n;i++)
	{
		int x; cin>>x;
		q.push_back(x);
	}
	while(m--)
	{
		int temp=q.back(); q.pop_back();
		q.push_front(temp);
	}
	for(auto t=q.begin();t!=q.end();t++)
	{
		cout<<*t;
		if(t+1!=q.end()) cout<<" ";
	}
	return 0;
}

第三种方法:

#include<iostream>
using namespace std;
int main(){
	int N,M;
	int num[100];
	scanf("%d %d",&N,&M);
	M=M%N;//防止越界
	for(int i=0;i<N;i++){
		scanf("%d",&num[i]);
	}
	for(int i=N-M;i<N;i++){
		printf("%d ",num[i]);
	}
	for(int i=0;i<N-M;i++){
		if(i!=0) printf(" ");
		printf("%d",num[i]);
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值