1. 程式人生 > >Problem C: 指標:有n個整數,使其前面各數順序向後移m個位置,最後m個數變成最前面m個數

Problem C: 指標:有n個整數,使其前面各數順序向後移m個位置,最後m個數變成最前面m個數

#include<stdio.h>
 int move(int *x,int n,int m)
 {
     int t[255];
     int i;
     //int *p;指標迴圈變數p
     for(i=0;i<n;i++)
         t[i]=x[i];
     for(i=0;i<m;i++)
         x[i]=t[n-m+i];
     for(i=m;i<n;i++)
         x[i]=t[i-m];
         /*指標變數做迴圈變數也可以。
    for(i=0,p=x;p<x+m;p++)
    *p=t[n-m+i++]; 
    for(i=0,p=x+m;p<x+n;p++)
    *p=t[i++];
        
*/ } int main() { int a[20]; int n,m; int i; while(scanf("%d%d",&n,&m)!=EOF) { for(i=0;i<n;i++) scanf("%d",&a[i]); move(a,n,m); for(i=0;i<n-1;i++) printf("%d ",a[i]); printf("%d",a[n-1]); printf("\n"); }
return 0; }