有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数。
**输入格式要求:"%d" 提示信息:“the total numbers is:” “back m:”
**输出格式要求:"%d," “%d”
例子
the total numbers is:5
back m:2
1 2 3 4 5
4,5,1,2,3
思路,设置两个数组,一个存放输入数组,另一个存放变化后的数组
#include <math.h>
#include<stdio.h>
#include<stdlib.h>
int main()
{ int i,n,m,p;
int a[20],b[20];
printf("the total numbers is:");
scanf("%d",&n);
printf("back m:");
scanf("%d",&m);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(i=0;i<n-m;i++) //关于数组下标的问题,如果觉得不好推敲,可以自己举例子
{
b[i+m]=a[i];
}
for(i=n-m,p=0;i<n;i++,p++) //共两个for循环存放需转换的数
{
b[p]=a[i];
}
for(i=0;i<n-1;i++) //这里注意做一下处理,不然后来输出末尾带0,其他的都还好
printf("%d,",b[i]);
printf("%d",b[i]);
}