首页 > 后端开发 > C++ > 正文

c++中如何转置二维数组_c++二维数组转置方法

穿越時空
发布: 2025-09-28 14:39:02
原创
458人浏览过
转置二维数组即行列互换,可通过嵌套循环实现;固定数组直接遍历赋值,vector动态数组灵活支持任意尺寸,方阵可原地交换元素节省空间。

c++中如何转置二维数组_c++二维数组转置方法

在C++中转置二维数组,本质是将矩阵的行和列互换。假设原数组为 matrix[i][j],转置后变为 matrix[j][i]。实现方式根据数组类型(普通数组、动态数组或使用STL)略有不同,以下是几种常用方法。

使用固定大小的二维数组

如果二维数组大小已知且固定,可以直接通过嵌套循环进行转置。

示例代码:

#include <iostream><br>using namespace std;<br><br>int main() {<br>    int matrix[3][3] = {<br>        {1, 2, 3},<br>        {4, 5, 6},<br> {7, 8, 9}<br>    };<br>    int transpose[3][3];<br><br>    // 转置操作<br>    for (int i = 0; i < 3; ++i) {<br>        for (int j = 0; j < 3; ++j) {<br>            transpose[j][i] = matrix[i][j];<br>        }<br>    }<br><br>    // 输出结果<br>    cout << "转置后的数组:\n";<br>    for (int i = 0; i < 3; ++i) {<br>        for (int j = 0; j < 3; ++j) {<br>            cout << transpose[i][j] << " ";<br>        }<br>        cout << endl;<br>    }<br>    return 0;<br>}
登录后复制

注意:此方法适用于编译时确定大小的数组。

使用vector实现动态二维数组转置

当数组大小在运行时才确定,推荐使用 std::vector<std::vector<int>> 来存储二维数据,并进行转置。

立即学习C++免费学习笔记(深入)”;

宣小二
宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

宣小二 21
查看详情 宣小二
示例代码:

#include <iostream><br>#include <vector><br>using namespace std;<br><br>vector<vector<int>> transposeMatrix(const vector<vector<int>>& matrix) {<br>    int rows = matrix.size();<br>    int cols = matrix[0].size();<br>    vector<vector<int>> transpose(cols, vector<int>(rows));<br><br>    for (int i = 0; i < rows; ++i) {<br>        for (int j = 0; j < cols; ++j) {<br>            transpose[j][i] = matrix[i][j];<br>        }<br>    }<br>    return transpose;<br>}<br><br>int main() {<br>    vector<vector<int>> matrix = {{1, 2, 3}, {4, 5, 6}};<br>    auto transposed = transposeMatrix(matrix);<br><br>    cout << "转置后:\n";<br>    for (const auto& row : transposed) {<br>        for (int val : row) {<br>            cout << val << " ";<br>        }<br>        cout << endl;<br>    }<br>    return 0;<br>}
登录后复制

这种方法灵活,支持任意行列数,且内存自动管理。

原地转置(仅限方阵)

对于行数等于列数的二维数组(即方阵),可以在不使用额外数组的情况下完成转置,通过交换 matrix[i][j]matrix[j][i] 实现。

for (int i = 0; i < n; ++i) {<br>    for (int j = i + 1; j < n; ++j) {<br>        swap(matrix[i][j], matrix[j][i]);<br>    }<br>}
登录后复制

注意内层从 j = i + 1 开始,避免重复交换导致还原。

基本上就这些常见方法。选择哪种取决于你的数组类型和是否需要原地操作。关键是理解转置就是行列索引互换。

以上就是c++++中如何转置二维数组_c++二维数组转置方法的详细内容,更多请关注php中文网其它相关文章!

相关标签:
c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号