浙大版《数据结构(第2版)》题目集-习题2.2 数组循环左移 (20分)
参考代码#include<stdio.h>void Reverse(int x[],int a,int b);void Output(int x[],int n);int main(){int n,m;scanf("%d%d",&n,&m);int x[n];int i;for(i=0;i<n;i++){scanf("%d",&x[i]);}m=m%n;.
·
参考代码
#include<stdio.h>
void Reverse(int x[],int a,int b);
void Output(int x[],int n);
int main()
{
int n,m;
scanf("%d%d",&n,&m);
int x[n];
int i;
for(i=0;i<n;i++)
{
scanf("%d",&x[i]);
}
m=m%n;
if(m==0)
{
Output(x,n);
}
else
{
Reverse(x,0,m-1);
Reverse(x,m,n-1);
Reverse(x,0,n-1);
Output(x,n);
}
return 0;
}
void Reverse(int x[],int a,int b)
{
int t;
while(b>=a)
{
t=x[a];
x[a]=x[b];
x[b]=t;
a++;
b--;
}
}
void Output(int x[],int n)
{
int i;
for(i=0;i<n;i++)
{
printf("%d",x[i]);
if(i==n-1)
{
printf("\n");
}
else
{
printf(" ");
}
}
}
思路:
例如题目中的
8 3
1 2 3 4 5 6 7 8
先将
1 2 3翻转为3 2 1
再将
4 5 6 7 8翻转为8 7 6 5 4
最后将整体翻转
3 2 1 8 7 6 5 4翻转为4 5 6 7 8 1 2 3

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)