# include"stdio.h"
void main()
{
int a[10]={1,2,3,4,5,6,7,8,9,10},b[10];
int i,j,k;
printf("移位前: ");
for(k=0;k<10;k++)
printf("%d ",a[k]);
printf("\n");
printf("Input i: ");
scanf("%d",&i);
j=i%10;
for(k=0;k<10;k++)
{
if(j==10)
j=0;
b[k]=a[j++];
}
for(k=0;k<10;k++)
a[k]=b[k];
printf("移位后: ");
for(k=0;k<10;k++)
printf("%d ",a[k]);
printf("\n");
}
思路:可以定义两个数组a和b,以及整数i,数组a用来存放原始数据,数组b用来存放移动过后的数据,依次把a的第i位到结束位置的数存放到b中,再把a的0位置到i位置数存放到b中,最终的b就是数组循环左移i位的最终结果。
//参考代码: