只是为了输出结果,可以强行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;
}









