概述
只是为了输出结果,可以强行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;
}
最后
以上就是沉静萝莉为你收集整理的C++实现1008 数组元素循环右移问题的全部内容,希望文章能够帮你解决C++实现1008 数组元素循环右移问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复