0
点赞
收藏
分享

微信扫一扫

C++实现1008 数组元素循环右移问题

49路末班车 2022-03-21 阅读 150
c++pat考试

只是为了输出结果,可以强行cout

#include<iostream>
using namespace std;
int main()
{
    int N,M;
    cin>>N>>M;
    M %= N;
    int vec[N];
    for(int i = 0;i < N;i++)
    {
        cin>>vec[i];
    }
    for(int j = N - M;j < N;j++)
        cout<<vec[j]<<" ";
    for(int j = 0;j < N - M - 1;j++)
        cout<<vec[j]<<" ";
    cout<<vec[N - M - 1];
    return 0;
}

不行,得正规一点,得写出点逻辑:

//注意M %= N,因为M可能大于N

#include<iostream>
using namespace std;
void reverse(int vec[], int start, int end){
	for(int i=start; i<=(start+end)/2; i++){
		int tmp = vec[i];
		vec[i] = vec[start+end-i];
		vec[start+end-i] = tmp;
	}
}
int main()
{
    int N,M;
    cin>>N>>M;
    M %= N;
    int vec[N];
    for(int i = 0;i < N;i++)
    {
        cin>>vec[i];
    }
    reverse(vec, 0, N-M-1);
	reverse(vec, N-M, N-1);
	reverse(vec, 0, N-1);
    for(int i = 0; i < N - 1; i++)
    {
		cout<<vec[i]<<" ";
	}
    cout<<vec[N - 1];
    return 0;
}
举报

相关推荐

0 条评论