转置矩阵:交换元素不会改变值

时间:2018-10-04 07:47:50

标签: c++ vector

我正在尝试转置由向量构建的矩阵。

这是我写的转置函数:

void transpose(std::vector<std::vector<int>>& fill_mat) {
    for (int i = 0; i < fill_mat.size(); ++i) {
        for (int j = 0; j < fill_mat.size(); ++j) {
            std::swap(fill_mat[i][j], fill_mat[j][i]);
        }
    }
}

似乎什么也没做:我的最终结果与开始的结果相同。


这是我的完整程序:

#include<iostream>
#include<vector>
#include<utility>

void print_matrix(std::vector<std::vector<int>>& to_print) {
    for (int i = 0; i < to_print.size(); ++i) {
        for (int j = 0; j < to_print.size(); ++j) {
            std::cout << " " << to_print[i][j];
        }
        std::cout << std::endl;
    }
}

void make_matrix(std::vector<std::vector<int>>& fill_mat) {
    for (int i = 0; i < fill_mat.size(); ++i) {
        for (int j = 0; j < fill_mat.size(); ++j) {
            fill_mat[i][j] = rand() % 15;
        }
    }
}

void transpose(std::vector<std::vector<int>>& fill_mat) {
    for (int i = 0; i < fill_mat.size(); ++i) {
        for (int j = 0; j < fill_mat.size(); ++j) {
            std::swap(fill_mat[i][j], fill_mat[j][i]);
        }
    }
}


int main() {
    int size = 3;
    std::vector<std::vector<int>> matrix_sample(size, std::vector<int>(size));

    make_matrix(matrix_sample);
    print_matrix(matrix_sample);

    transpose(matrix_sample);

    std::cout << "----## transpose ##-----" << std::endl;
    print_matrix(matrix_sample);
}

我希望打印出转置矩阵,但输入最终与输出相同。我在做什么错了?

1 个答案:

答案 0 :(得分:5)

您将(i,j)与(j,i)交换了两次!这就是为什么它无效的原因。

您应该只处理矩阵的一半。加上未成年人的改善,我们得到:

void transpose(std::vector<std::vector<int>>& fill_mat)
{
    using size_type = decltype(fill_mat)::size_type; // better use your matrix' size type
    for (size_type i = 0; i < fill_mat.size(); ++i) {
        for (size_type j = 0; j < i; ++j) {
            using std::swap; // see swap idiom
            swap(fill_mat[i][j], fill_mat[j][i]);
        }
    }
}