C语言-方阵循环右移

本题要求编写程序,将给定n×n方阵中的每个元素循环向右移m个位置,即将第0、1、⋯、n−1列变换为第n−m、n−m+1、⋯、n−1、0、1、⋯、n−m−1列。

输入格式:

输入第一行给出两个正整数m和n(1≤n≤6)。接下来一共n行,每行n个整数,表示一个n阶的方阵。

输出格式:

按照输入格式输出移动后的方阵:即输出n行,每行n个整数,每个整数后输出一个空格。

输入样例:

复制代码
2 3
1 2 3
4 5 6
7 8 9

输出样例:

复制代码
2 3 1 
5 6 4 
8 9 7 
cpp 复制代码
#include "stdio.h"
//矩阵右移函数
void MatrixShiftRight(int arr[][6],int pow){
    //总行后一位值寄存器1
    int temp1;
    for (int i = 0; i < pow; ++i) {
        //换行刷新
        temp1 = 0;
        for (int j = 0; j < pow; ++j) {
            //如果当前为该行最后一位
            if (j+1 == pow){
                arr[i][0] = temp1;
            //如果当前为该行第一位
            } else if(j == 0){
                temp1 = arr[i][j+1];
                arr[i][j+1] = arr[i][j];
            //如果当前为非首尾位
            } else{
                //后一位值寄存器2
                int temp2 = arr[i][j+1];
                arr[i][j+1] = temp1;
                temp1 = temp2;
            }
        }
    }
}
int main(){
    int times,pow;
    scanf("%d %d",&times,&pow);
    int arr[6][6];
    for (int i = 0; i < pow; ++i) {
        for (int j = 0; j < pow; ++j) {
            scanf("%d",&arr[i][j]);
        }
    }
    //方阵循环右移
    while (times--){
        //调用矩阵右移函数
        MatrixShiftRight(arr,pow);
    }
    for (int i = 0; i < pow; ++i) {
        for (int j = 0; j < pow; ++j) {
            printf("%d ",arr[i][j]);
            if(j+1 == pow)
                printf("\n");
        }
    }
    return 0;
}

以上代码全为本人亲自手敲,可能有一些错误和不足之处,如有更好的方法和建议,欢迎您在评论区友善讨论。

相关推荐
小超超爱学习99376 分钟前
大数乘法,超级简单模板
开发语言·c++·算法
Ricardo-Yang20 分钟前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
凌波粒21 分钟前
LeetCode--344.反转字符串(字符串/双指针法)
算法·leetcode·职场和发展
啊哦呃咦唔鱼29 分钟前
LeetCode hot100-543 二叉树的直径
算法·leetcode·职场和发展
soragui1 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
sinat_286945191 小时前
harness engineering
人工智能·算法·chatgpt
少许极端1 小时前
算法奇妙屋(四十三)-贪心算法学习之路10
学习·算法·贪心算法
samroom1 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探2 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
样例过了就是过了2 小时前
LeetCode热题100 爬楼梯
c++·算法·leetcode·动态规划