|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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];
- }
- //还没有实现输入移动几位的功能,只能事先预设移动的位数
复制代码
|
|