博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
动态创建二维素组
阅读量:7279 次
发布时间:2019-06-30

本文共 1475 字,大约阅读时间需要 4 分钟。

有时候在创建数组之前,不知道具体几行或列(比如说,我们将数据库中的数据取出,知道列数,而行数是不确定的),这是我们需要动态创建数组:

两种方法:

1.转化为一维数组申请
2.先申请全部行首指针,再按行逐行申请
1.
a=(int *)malloc(sizeof(int),(unsigned)m*n);
使用的时候就和一般的二维数组一样。
举个例子给你:
#include "stdlib.h" 
#include "stdio.h" 
#include 
int main() 
  int i,j; 
  int n;//这个就是需要指定的行数
  int (*p)[10]; 
  scanf("%d",&n);//取得行数
//动态生成二维数组,指定列数为10,如果想改,自己该里面 
的参数,如果想定义n行2列就为: p=(int (*)[2])malloc(n*2*sizeof(int)); 

 p=(int (*)[10])malloc(n*10*sizeof(int)); //动态申请n行10列的二维数组

for(i=0;i<n;i++)

{

  for(j=0;j<10;j++)

  {

    p[i][j]=i*j;

  } 

}

for(i=0;i<n;i++)

{

  for(j=0;j<10;j++)

  {

    printf("%d",p[i][j]);

  } 

  printf("\n");

}

free(p); 
return 0; 
}
2
.

这个也给你举个例子吧:

#include 

#include 
main() 
  int i = 0; 
  int j = 0; 
  int line = 0; 
  int row = 0; 
  int **p = NULL; 
  printf("input the line of the array:\n"); 
  scanf("%d", &line); 
  printf("input the row of the array:\n"); 
  scanf("%d", &row); 
  p = (int **)malloc(sizeof(int *) * line); 
  i
f (NULL == p) 

  { 

    return; 
  } 
  for (i = 0; i < line; i++) 
  { 
  *(p + i) = (int *)malloc(sizeof(int) * row); 
  if (NULL == *(p + i)) 
  { 
  return; 
  } 
  } 
/*input data*/ 
for (i = 0; i < line; i++) 
  for(j = 0; j < row; j++) 
  { 
    p[i][j] = i + 1; 
  } 
  } 
/*output data*/ 
for (i = 0; i < line; i++) 
  for(j = 0; j < row; j++) 
  { 
    printf("%d", p[i][j]); 
  } 
/*free every line point*/ 
for (i = 0; i < line; i++) 
  free(*(p + i)); 
  p[i] = NULL; 
free(p); 
p = NULL; 
}

转载于:https://www.cnblogs.com/zhaihongliangblogger/p/6194379.html

你可能感兴趣的文章
计数排序,桶排序与基数排序
查看>>
Android 项目目录结构
查看>>
一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](九)
查看>>
Facebook Docusaurus 中文文档 添加博客
查看>>
JavaScript温故(一)
查看>>
醒来或者吃饱又是一年
查看>>
Spark入门
查看>>
Angular 5 开发一个有道翻译
查看>>
charm_PHP,一个还有诸多问题的PHP MVC框架
查看>>
Python 类继承相关问题
查看>>
第五部分:Intellj IDEA插件介绍
查看>>
微服务关键概念脑图梳理
查看>>
PhantomJS,隐身浏览器
查看>>
【252天】我爱刷题系列(11)
查看>>
npm入手笔记0x002-发布自己的Node.js模块及其版本管理
查看>>
敏感词检测算法小结
查看>>
async/await with webpack+babel in Browser
查看>>
thinkphp邮箱验证码前后台
查看>>
2017-06-25 前端日报
查看>>
nginx域名配置非80端口的301跳转
查看>>