Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,851 questions

51,772 answers

573 users

How to dynamically allocate a 2D array of ints using pointer to a pointer in C

2 Answers

0 votes
#include <stdio.h>
#include <stdlib.h>
 
int main(void)
{
    int row = 3, col = 4;
    
    int **arr = (int **)malloc(row * sizeof(int *));
    for (int i = 0; i < row; i++)
         arr[i] = (int *)malloc(row * sizeof(int));
 
    for (int i = 0; i < row; i++)
      for (int j = 0; j < col; j++)
            arr[i][j] = i + j;
 
    for (int i = 0; i < row; i++)
    {
       for (int j = 0; j < col; j++)
          printf("%d ", arr[i][j]);
       printf("\n"); 
    }
    
    for (int i = 0; i < row; i++)
        free(arr[i]);
    free(arr);

    return 0;
}
 
   
/*
run:
  
0 1 2 3
1 2 3 4
2 3 4 5

*/

 



answered Jul 28, 2017 by avibootz
0 votes
#include <stdio.h>
#include <stdlib.h>
  
int main(void)
{
    int row = 3, col = 4;
  
    int **arr  = (int **)malloc(sizeof(int *) * row);
    arr[0] = (int *)malloc(sizeof(int) * col * row);
 
    for(int i = 0; i < row; i++)
        arr[i] = (*arr + col * i);
 
    for (int i = 0; i < row; i++)
      for (int j = 0; j < col; j++)
            arr[i][j] = i + j;
 
    for (int i = 0; i < row; i++)
    {
       for (int j = 0; j < col; j++)
          printf("%d ", arr[i][j]);
       printf("\n"); 
    }
    
    free(arr[0]);
    free(arr);
  
    return 0;
}
  
    
/*
run:
      
0 1 2 3
1 2 3 4
2 3 4 5
  
*/

 



answered Jul 28, 2017 by avibootz

Related questions

1 answer 171 views
2 answers 170 views
1 answer 207 views
1 answer 109 views
1 answer 198 views
...