• PTA 数组循环右移


    6-2 数组循环右移 (20 分)
     

    本题要求实现一个对数组进行循环右移的简单函数:一个数组a中存有n(>)个整数,将每个整数循环向右移m(≥)个位置,即将a中的数据由(a0​​a1​​an1​​)变换为(anm​​an1​​a0​​a1​​anm1​​)(最后m个数循环移至最前面的m个位置)。

    函数接口定义:

    int ArrayShift( int a[], int n, int m );
    

    其中a[]是用户传入的数组;n是数组的大小;m是右移的位数。函数ArrayShift须将循环右移后的数组仍然存在a[]中。

    裁判测试程序样例:

    #include <stdio.h>
    #define MAXN 10
    
    int ArrayShift( int a[], int n, int m );
    
    int main()
    {
        int a[MAXN], n, m;
        int i;
    
        scanf("%d %d", &n, &m);
        for ( i = 0; i < n; i++ ) scanf("%d", &a[i]);
    
        ArrayShift(a, n, m);
    
        for ( i = 0; i < n; i++ ) {
            if (i != 0) printf(" ");
            printf("%d", a[i]);
        }
        printf("
    ");
    
        return 0;
    }
    
    /* 你的代码将被嵌在这里 */
    

    输入样例:

    6 2
    1 2 3 4 5 6
    

    输出样例:

    5 6 1 2 3 4

     1 int ArrayShift( int a[], int n, int m ){
     2     int t=0;
     3     for(int j=0;j<m;j++){
     4         t=a[n-1];
     5         for(int i=n-1;i>0;i--){
     6             
     7             a[i]=a[i-1];
     8         }
     9         a[0]=t;
    10     }
    11     return 1;
    12 }
  • 相关阅读:
    【leetcode】下一个排列
    【leetcode】配对交换
    【leetcode】两个相同字符之间的最长子字符串
    052-126&127
    052-125
    052-124
    052-123
    052-122
    052-121
    052-120
  • 原文地址:https://www.cnblogs.com/DirWang/p/11929571.html
Copyright © 2020-2023  润新知