基于方向键实现矩阵选择

目录

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

相关推荐
浅念-1 天前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Kiling_07041 天前
Java集合进阶:Set与Collections详解
算法·哈希算法
智者知已应修善业1 天前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
洛水水1 天前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI1 天前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞1 天前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb12111 天前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora1 天前
Python 算法基础篇之集合
python·算法
平行侠1 天前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完1 天前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表