| 
 | 
 
 
发表于 2023-10-28 10:54:59
|
显示全部楼层
 
 
 
你可以使用C++编写一个矩阵转置函数,可以根据用户输入的行数和列数来创建矩阵,并将其转置。下面是一个示例代码: 
 
- #include <iostream>
 
 - #include <vector>
 
  
- // 定义矩阵转置函数
 
 - std::vector<std::vector<int>> transposeMatrix(int rows, int columns) {
 
 -     // 创建原始矩阵
 
 -     std::vector<std::vector<int>> matrix(rows, std::vector<int>(columns));
 
  
-     // 输入矩阵元素
 
 -     std::cout << "请输入矩阵元素:" << std::endl;
 
 -     for (int i = 0; i < rows; i++) {
 
 -         for (int j = 0; j < columns; j++) {
 
 -             std::cin >> matrix[ i][j];
 
 -         }
 
 -     }
 
  
-     // 创建转置矩阵
 
 -     std::vector<std::vector<int>> transpose(columns, std::vector<int>(rows));
 
  
-     // 进行矩阵转置
 
 -     for (int i = 0; i < rows; i++) {
 
 -         for (int j = 0; j < columns; j++) {
 
 -             transpose[j][ i] = matrix[ i][j];
 
 -         }
 
 -     }
 
  
-     return transpose;
 
 - }
 
  
- int main() {
 
 -     int rows, columns;
 
 -     std::cout << "请输入矩阵的行数:";
 
 -     std::cin >> rows;
 
 -     std::cout << "请输入矩阵的列数:";
 
 -     std::cin >> columns;
 
  
-     std::vector<std::vector<int>> transposedMatrix = transposeMatrix(rows, columns);
 
  
-     // 输出转置矩阵
 
 -     std::cout << "转置矩阵:" << std::endl;
 
 -     for (int i = 0; i < transposedMatrix.size(); i++) {
 
 -         for (int j = 0; j < transposedMatrix[0].size(); j++) {
 
 -             std::cout << transposedMatrix[ i][j] << " ";
 
 -         }
 
 -         std::cout << std::endl;
 
 -     }
 
  
-     return 0;
 
 - }
 
 
  复制代码 
 
这个程序首先会要求用户输入矩阵的行数和列数,然后根据用户输入创建原始矩阵,并输入矩阵元素。接着,它会创建一个转置矩阵,并将原始矩阵转置存储到转置矩阵中。最后,程序会输出转置后的矩阵。 
 
希望这个程序能够帮助到你!如果你有任何问题,请随时提问。 |   
 
 
 
 |