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