马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
课本上的问题:
输入n个整数,使前面个数顺序向后移动m个位置,然后把后面的m个数移动变成前面的m个数 。用一个函数实现上面功能,然后输出调整后的n个数,利用指针。
例如 输入:1 2 3 4 5 6 7 8 9
向后移动2位变成:8 9 1 2 3 4 5 6 7
我自己写了程序#include<stdio.h>
#include<windows.h>
#define N 100
void main()
{
int *p;
int s[N],temp,i=0,j;
void fun(int *s,int j);
p=s;
printf("please input array(以非阿拉伯数做为结束):\n");
while((scanf("%d",&temp)==1)&&(i<N)) //数组的输入
{
*(p+i)=temp;
i++;
}
j=i;
p=s;
printf("原数组为:");
for(i=0;i<j;i++)
printf("%d ",*(p+i));
printf("\n");
fun(s,j);
p=s;
printf("移动后数组为:");
for(i=0;i<j;i++)
printf("%d ",*(p+i));
printf("\n");
system("pause");
}
void fun(int *s,int j)
{
int m,i,*p1,*p2,n,a[N],k; //利用数组a来接受数组s的置换,然后在把数组a复制到数组s
p1=s;
p2=a;
printf("请输入要移动的位数:");
scanf("%d",&m); //要移动的位数 无法对m赋值
printf("%d",m);
for(i=0;i<(j-m);i++,p1++) //第一部分的复制
*(p2+i+m)=*p1; //会中断 如果事先对m赋值如m=2则不会有问题
for(i=0;i<m;i++,p1++) //第二部分复制
a[i]=*p1;
for(i=0;i<j;i++) //将复制的数组复制到原数组
s[i]=a[i];
}
//还没有实现输入移动几位的功能,只能事先预设移动的位数
|