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

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

相关推荐
退休倒计时22 分钟前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
旖-旎24 分钟前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
戴西软件36 分钟前
戴西 DLM 许可授权管理系统:破解无网络环境下工业软件授权难题,助力制造企业降本增效
网络·人工智能·python·深度学习·程序人生·算法·制造
2601_961875241 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
无限码力1 小时前
美团研发岗 4月18号笔试真题 - 坐标
算法·美团笔试真题·美团笔试题·美团研发岗笔试题·美团研发岗4月18号真题
有点。2 小时前
C++倍增法(练习题)
c++·算法
2601_950526432 小时前
程序设计语言(C)
c语言·数据类型·实验教学·编译预处理·程序设计语言(c)
不会C语言的男孩2 小时前
Linux 系统编程 · 第 4 章:文件属性与元数据
linux·c语言·开发语言
C语言小火车2 小时前
什么时候用智能指针?什么时候用裸指针?
c语言·c++·学习·指针