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;
 } 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM