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

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

相关推荐
We་ct4 小时前
LeetCode 124. 二叉树中的最大路径和:刷题解析
前端·数据结构·算法·leetcode·typescript
见叶之秋5 小时前
C语言--动态内存管理
c语言·开发语言
Once_day7 小时前
C++之《程序员自我修养》读书总结(5)
c语言·c++·编译和链接·程序员自我修养
Anastasiozzzz7 小时前
MySQL JOIN:底层原理、算法演进与多表性能之谜
算法
元亓亓亓7 小时前
考研408--数据结构--day15--排序&内部排序(上)
数据结构·408·排序·内部排序
追随者永远是胜利者13 小时前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
会周易的程序员13 小时前
cNetgate物联网网关内存数据表和数据视图模块架构
c语言·c++·物联网·架构·lua·iot
Jason_Honey213 小时前
【平安Agent算法岗面试-二面】
人工智能·算法·面试
爱编码的小八嘎13 小时前
第3章 Windows运行机理-3.1 内核分析(6)
c语言
宇木灵13 小时前
C语言基础-十、文件操作
c语言·开发语言·学习