您现在的位置是:首页 > 正文

C++ 动态开辟二维数组的的方法

2024-02-01 01:14:44阅读 2

    近日写到一个程序,用到了要动态开辟二维数组,一想,自己就会两种。一者:用new在堆上开辟;二者:用vector开辟。技巧没有多少,但是确实是折腾了我半天!首先,大家去网上搜一下,动态开辟二维数组的文章特别多,再加上我这篇就更多了,我本不想写这篇博文的。但看了网上各位“大虾”“大牛”写的,觉得还是有必要写一下!给各位讲清楚点,以防被网上质量残次不齐的文章误导了。

   写文章者,都是学习总结之用!为了是自己的快活,也为了别人的参考方便。

   那我想在就讲讲我经常用到的两种方法;

   一:C++ new 法

   首先贴出我写的一个小小的代码吧!以供大家评论!代码都经本人在VC++ 6.0上编译运行过,无错!至于有高手再能找出bug,那就给我提出来吧,我也进步,进步!

#include <iostream>
#include <iomanip>

using namespace std;

void main()
{
    int row, col;
    int **element = NULL;

    cin>>row
        >>col;

    //动态开辟数组
    element = new int *[row];

    for (int i = 0; i < row; i++)
    {
        element[i] = new int[col];
    }


    //输入数组
    cout<<endl;

    for (i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            cin>>element[i][j];
        }
    }

    //输出数组
    cout<<endl;

    for (i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            cout<<setw(5)<<element[i][j];
        }
        cout<<endl;
    }
}

 

关键之处我用红笔标绘出来了!大家肯定一看就懂了!

但是,有时对于新手来说,确实很懵懂的。开辟一维数组是何等简单,但是二维数组还是用开辟一维数组的思想!

程序不足之处是没有销毁开辟的空间!那大家在看看销毁的代码吧!

//销毁空间
    for (i = 0; i < row; i++)
    {
        delete []element[i];
        element[i] = NULL;
    }
    delete []element;
    element = NULL;

这是销毁开辟的空间的代码!

用new在堆上开辟的空间,必须要用delete释放了,不然要出现内存泄露了!

 

     二:vector法

学习C++,就不得不学习STL了。用vector开辟二维数组也不失为一个好办法!

首先看一段代码!

#include <iostream>
#include <vector>
#include <iomanip>

using namespace std;

void main()
{
    int row, col;
    cout<<"请输入行列值:";
    cin>>row
        >>col;

    vector<vector<int> > test(row, vector<int>(col)); //声明一个二维数组,注意这里的空格不能少

    //初始化,其实不初始化也是可以的,vector默认是0
    for (int i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            test[i][j] = 0;
        }
    }

    cout<<endl;

    //输出值
    for (i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            cout<<setw(5)<<test[i][j];
        }

        cout<<endl;
    }

    //输出行列值
    cout<<"行:"<<test.size()<<endl;
    cout<<"列:"<<test[1].size()<<endl;
}

 

编译时两次调用vector的构造函数对象test,第一次调用构造一个无名的含有col个0的vector<int>对象.

第二次调用构造函数,以这个无名向量为初始值初始化它的row个元素!

 

文章写到这里到此为止,希望对这里还有迷茫的人有所帮助,也希望你们提出意见,对我的代码书写规范之处提出宝贵的意见!大家互相学习!

转载于:https://www.cnblogs.com/JPAORM/archive/2010/09/27/2509922.html

网站文章

  • jmeter结果合并_JMeter:生成多维度的HTML报告

    作者:wang.lan摘要:本篇文章主要讲解jmeter性能测试工具在生成测试报告方面一直有所欠缺,但是JMeter在3.0以后解决了这个问题.JMeter3.0以后引入了Dashboard Repo...

    2024-02-01 01:14:15
  • HystrixRPC保护的原理,HystrixCommand命令的执行方法

    HystrixRPC保护的原理,HystrixCommand命令的执行方法

    HystrixCommand命令的执行方法 前面讲到,独立使用HystrixCommand命令主要有以下两个步骤: (1)继承HystrixCommand类,将正常的业务逻辑实现在继承的run方法中,...

    2024-02-01 01:14:09
  • SpringBoot配置

    SpringBoot配置

    配置文件分类Spring boot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用application.properties或者 application.ym...

    2024-02-01 01:14:00
  • 【设计模式】桥接模式

    【设计模式】桥接模式

    设计模式大总结 桥梁模式是对象的结构模式。又称为柄体(Handle and Body)模式或接口(Interface)模式。桥梁模式的用意是“将抽象化(Abstraction)与实现化(Implementation)脱耦,使得二者可以独立地变化”。一。简解桥接模式顾名思义,是在两个模块间搭的一个桥,这两个模块就是抽象化和实现 抽象由抽象类或者接口声明的,作为一类类的抽象 实现则是继承抽象类或者

    2024-02-01 01:13:32
  • Android中根据手机的分辨率dp和px之间的转换

    public class UnitUtil { /** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public static int dp2px(Context context, float dpValue) { final float scale = context.getResources().getDisplay...

    2024-02-01 01:13:24
  • 理解KMP算法

    理解KMP算法

    KMP算法用于字符串模式匹配,目标串T=[T1.....Tn],模式串P=[P1....Pm],这里n>=m,i代表T的索引指针,j代表P的索引指针,传统字符串匹配算法,在Ti!=Pj的时候,i指针需要回退到i-j的位置,同时j回退到0,也就是模式串P开始的位置,这样传统算法的匹配过程的复杂度就是O(m*n)。其实在Ti!=Pj的时候,i指针不需要回退,[Ti-j+1...Ti-1]和[P1...

    2024-02-01 01:13:16
  • 微电子学与计算机期刊2019,微电子与通信工程学院研究生两篇论文被人工智能顶级会议AAAI 2019接收...

    微电子学与计算机期刊2019,微电子与通信工程学院研究生两篇论文被人工智能顶级会议AAAI 2019接收...

    近日,微电子与通信工程学院研究生有两篇文章被国际人工智能领域顶级学术会议AAAI 2019(AAAI Conference on Artificial Intelligence 2019)录用。AAA...

    2024-02-01 01:12:50
  • linux get current thread count and system threads limit

    get current thread count grep -s '^Threads' /proc/[0-9]*/status | awk '{ sum += $2; } END { print sum; }'get the system thread limitcat /proc/sys/kernel/threads-max转载于:https://www.cnblogs.com/l...

    2024-02-01 01:12:37
  • Linux实战操作

    Linux实战操作

    LinuxLinux目录一、pandas是什么?二、使用步骤1.引入库2.读入数据总结Linux目录登录系统后,在当前命令窗口下输入命令:查看linux目录ls / 或 ll /bin->user/...

    2024-02-01 01:12:30
  • vue3.0 store抽离,模块导入

    store/index.js import Vue from &#39;vue&#39; import Vuex from &#39;vuex&#39; import getters from &#3...

    2024-02-01 01:12:02