利用指针和迭代器遍历二维数组以及遍历顺序

发布于 2021-10-23  583 次阅读


内容纲要

可以看到是先遍历第一个参数较小的行/列,这应该也是内存中数组的数据储存顺序

#include<iostream>

using namespace std;

int main()
{
    int ia[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};
    for (auto p = ia; p != ia + 3; p++) { //指针
        for (auto q = *p; q != *p + 4; q++)
              cout << *q << ' ';
    cout << endl;
    }

    int ib[3][4] = { 2,4,6,8,10,12,14,16,18,20,22,24 };
    for (auto p = begin(ib); p != end(ib); p++) //迭代器
    {
        for (auto q = begin(*p); q != end(*p); q++)
            cout << *q << ' ';
        cout << endl;
    }
    return 0;
}

不爱嘉然小姐十年了。十年里,爱过的每个人都像她。