基于方向键实现矩阵选择

目录

4*3

要实现上下左右OK五个按键来操作一个4x3矩阵,您可以按照类似的思路进行编程。以下是一个示例代码:

c 复制代码
#include <stdio.h>

#define ROWS 4
#define COLS 3

int matrix[ROWS][COLS] = {
    {1, 2, 3},
    {4, 5, 6},
    {7, 8, 9},
    {10, 11, 12}
};

void printMatrix() {
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS; j++) {
            printf("%-2d ", matrix[i][j]);
        }
        printf("\n");
    }
    printf("\n");
}

void moveUp() {
    int temp[COLS];
    for (int j = 0; j < COLS; j++) {
        temp[j] = matrix[0][j];
    }
    for (int i = 0; i < ROWS - 1; i++) {
        for (int j = 0; j < COLS; j++) {
            matrix[i][j] = matrix[i + 1][j];
        }
    }
    for (int j = 0; j < COLS; j++) {
        matrix[ROWS - 1][j] = temp[j];
    }
}

void moveDown() {
    int temp[COLS];
    for (int j = 0; j < COLS; j++) {
        temp[j] = matrix[ROWS - 1][j];
    }
    for (int i = ROWS - 1; i > 0; i--) {
        for (int j = 0; j < COLS; j++) {
            matrix[i][j] = matrix[i - 1][j];
        }
    }
    for (int j = 0; j < COLS; j++) {
        matrix[0][j] = temp[j];
    }
}

void moveLeft() {
    int temp[ROWS];
    for (int i = 0; i < ROWS; i++) {
        temp[i] = matrix[i][0];
    }
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS - 1; j++) {
            matrix[i][j] = matrix[i][j + 1];
        }
    }
    for (int i = 0; i < ROWS; i++) {
        matrix[i][COLS - 1] = temp[i];
    }
}

void moveRight() {
    int temp[ROWS];
    for (int i = 0; i < ROWS; i++) {
        temp[i] = matrix[i][COLS - 1];
    }
    for (int i = 0; i < ROWS; i++) {
        for (int j = COLS - 1; j > 0; j--) {
            matrix[i][j] = matrix[i][j - 1];
        }
    }
    for (int i = 0; i < ROWS; i++) {
        matrix[i][0] = temp[i];
    }
}

void pressOK() {
    int sum = 0;
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS; j++) {
            sum += matrix[i][j];
        }
    }
    printf("Sum: %d\n", sum);
}

int main() {
    int choice;

    while (1) {
        printMatrix();
        printf("Press 1: Up, 2: Down, 3: Left, 4: Right, 5: OK\n");
        printf("Enter your choice: ");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                moveUp();
                break;
            case 2:
                moveDown();
                break;
            case 3:
                moveLeft();
                break;
            case 4:
                moveRight();
                break;
            case 5:
                pressOK();
                break;
            default:
                printf("Invalid choice!\n");
        }

        printf("\n");
    }

    return 0;
}

这个示例与之前的示例非常相似,只是调整了矩阵的行和列的顺序,以适应4x3的矩阵。移动操作的实现也有一些微调。

3*4

要实现上下左右OK五个按键来操作一个3x4矩阵,您可以使用一个二维数组来表示该矩阵,并利用按键输入来进行矩阵操作。以下是一个示例代码:

c 复制代码
#include <stdio.h>

#define ROWS 3
#define COLS 4

int matrix[ROWS][COLS] = {
    {1, 2, 3, 4},
    {5, 6, 7, 8},
    {9, 10, 11, 12}
};

void printMatrix() {
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS; j++) {
            printf("%-2d ", matrix[i][j]);
        }
        printf("\n");
    }
    printf("\n");
}

void moveUp() {
    int temp = matrix[0][0];
    for (int i = 0; i < ROWS - 1; i++) {
        for (int j = 0; j < COLS; j++) {
            matrix[i][j] = matrix[i + 1][j];
        }
    }
    for (int j = 0; j < COLS; j++) {
        matrix[ROWS - 1][j] = temp;
    }
}

void moveDown() {
    int temp = matrix[ROWS - 1][0];
    for (int i = ROWS - 1; i > 0; i--) {
        for (int j = 0; j < COLS; j++) {
            matrix[i][j] = matrix[i - 1][j];
        }
    }
    for (int j = 0; j < COLS; j++) {
        matrix[0][j] = temp;
    }
}

void moveLeft() {
    int temp = matrix[0][0];
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS - 1; j++) {
            matrix[i][j] = matrix[i][j + 1];
        }
    }
    for (int i = 0; i < ROWS; i++) {
        matrix[i][COLS - 1] = temp;
    }
}

void moveRight() {
    int temp = matrix[0][COLS - 1];
    for (int i = 0; i < ROWS; i++) {
        for (int j = COLS - 1; j > 0; j--) {
            matrix[i][j] = matrix[i][j - 1];
        }
    }
    for (int i = 0; i < ROWS; i++) {
        matrix[i][0] = temp;
    }
}

void pressOK() {
    int sum = 0;
    for (int i = 0; i < ROWS; i++) {
        for (int j = 0; j < COLS; j++) {
            sum += matrix[i][j];
        }
    }
    printf("Sum: %d\n", sum);
}

int main() {
    int choice;

    while (1) {
        printMatrix();
        printf("Press 1: Up, 2: Down, 3: Left, 4: Right, 5: OK\n");
        printf("Enter your choice: ");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                moveUp();
                break;
            case 2:
                moveDown();
                break;
            case 3:
                moveLeft();
                break;
            case 4:
                moveRight();
                break;
            case 5:
                pressOK();
                break;
            default:
                printf("Invalid choice!\n");
        }

        printf("\n");
    }

    return 0;
}

在这个示例中,我们定义了一个3x4矩阵matrix,以及相应的按键操作函数。printMatrix函数用于打印矩阵。moveUpmoveDownmoveLeftmoveRight函数分别实现了上、下、左、右按键的移动操作,将矩阵按指定方向进行移动。pressOK函数用于计算矩阵中所有元素的和。

main函数中,我们通过一个循环来接受用户的按键输入,并根据选择调用相应的按键操作函数或打印矩阵的和。

相关推荐
lbb 小魔仙3 小时前
面向 NPU 的高性能矩阵乘法:CANN ops-nn 算子库架构与优化技术
线性代数·矩阵·架构
空白诗3 小时前
CANN ops-nn 算子解读:大语言模型推理中的 MatMul 矩阵乘实现
人工智能·语言模型·矩阵
Wei&Yan4 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
团子的二进制世界4 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡4 小时前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨4 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3164 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
近津薪荼5 小时前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
熊文豪5 小时前
探索CANN ops-nn:高性能哈希算子技术解读
算法·哈希算法·cann
熊猫_豆豆5 小时前
YOLOP车道检测
人工智能·python·算法