• Skip to main content
  • Skip to primary sidebar
  • Skip to secondary sidebar
  • Skip to footer

Computer Notes

Library
    • Computer Fundamental
    • Computer Memory
    • DBMS Tutorial
    • Operating System
    • Computer Networking
    • C Programming
    • C++ Programming
    • Java Programming
    • C# Programming
    • SQL Tutorial
    • Management Tutorial
    • Computer Graphics
    • Compiler Design
    • Style Sheet
    • JavaScript Tutorial
    • Html Tutorial
    • Wordpress Tutorial
    • Python Tutorial
    • PHP Tutorial
    • JSP Tutorial
    • AngularJS Tutorial
    • Data Structures
    • E Commerce Tutorial
    • Visual Basic
    • Structs2 Tutorial
    • Digital Electronics
    • Internet Terms
    • Servlet Tutorial
    • Software Engineering
    • Interviews Questions
    • Basic Terms
    • Troubleshooting
Menu

Header Right

Home » C » Array » What is Dynamic Vectors in C
Next →
← Prev

What is Dynamic Vectors in C

By Dinesh Thakur

As we know, a pointer to type T is analogous to an array of type T.A pointer can be used to represent a vector, as illustrated in Fig. When a pointer is declared, the memory is allocated only for the pointer variable. The memory for the array elements is usually allocated separately using dynamic memory allocation functions, namely, malloc or calloc.

               

The function ivec_alloc, that dynamically allocates an integer vector containing n elements and returns a pointer to the allocated memory block, is given below. Note that the function return type is int*.

int *ivec_alloc(int n)

{

   int *tmp = (int*) malloc(n * sizeof(int));

   if (tmp == NULL) {

   printf(“Error: Out of memory …\n”);

   exit(l);

}

   return tmp;

}

This function accepts an array size (n) and allocates memory for the array, i. e., n * sizeof (int)bytes, to a temporary integer pointer tmp. This pointer is returned to the calling function. However, if the memory allocation is unsuccessful, it displays an error message and exits with error code 1. Thus, we require only a single line call to allocate a dynamic array as shown below.

int *a;

a= ivec_alloc(100); /* allocate 100 element int array */

Note that the pointer variable tmp is local to the function and will be destroyed when the function returns. However, the address of the allocated memory block is returned to the calling function, and we can continue to use the block as a vector (through pointer a in above example) until we explicitly free its memory using free function.

Finally note that the above function is written specifically for the allocation of an integer vector and we need to write a separate function for the vector of each type required in the program. For this, we should first change the function name, say fvec_alloc for float type, cvec_alloc for char type, sivec_alloc for short int type, etc. Also, we should replace each int keyword (other than that in the function parameter declaration, int n) with the desired type. For example, function fvec_alloc for allocation of a float vector is given below.

float *fvec_alloc(int n)

{

   float *tmp = (float*) malloc(n * sizeof(float));

   if (tmp == NULL) {

   printf(“Error: Out of memory …\n”);

   exit(1);

}

return tmp;

}

C Program for read a dynamic vector and print it in reverse order

A program to read a dynamic vector of type float and print it in reverse order is given below. It first reads the array size (n) from the keyboard and allocates a dynamic vector of that size using the fvec_alloc function. Then a for loop is used to read array elements from the keyboard and another for loop is used to print the array in reverse order. Observe that the elements of the dynamic array are accessed using the usual subscript notation, a [i ]. Finally, the memory allocated to the array is freed and the program ends. Note that the program includes the stdlib.h header file.

#include <stdio.h>

#include <stdlib.h>

float * fvec_alloc(int n);

void main ()

{

       float *a;   /* pointer for dynamic array */

       int i, n;

       printf(“Enter vector size: “);

       scanf(“%d”, &n);

       a= fvec_alloc(n);     /* allocate vector */

       /* read a vector */

       printf(“Enter vector elements: “);

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

       scanf(“%f”, &a[i]);

       /* print a vector */

       printf(“Given vector in reverse order: “);

       for (i = n – 1; i >= 0; i–)

       printf(“%5.2f “, a[i]);

       printf(“\n”);

       free(a); /* free vector */

       getch();

}

/* include definition of fvec alloc function here */

The program output is given below.

Enter vector size: 2

Enter vector elements: 1.2 2.3 3.4 4.5 5.6

Given vector in reverse order: 5.60 4.50 3.40 2.30 1.20

You’ll also like:

  1. const Vectors in C
  2. C program to add two vectors of size n
  3. What is Dynamic Arrays in C
  4. Vectors and Pointers in C
  5. Vectors with Structures in C
Next →
← Prev
Like/Subscribe us for latest updates     

About Dinesh Thakur
Dinesh ThakurDinesh Thakur holds an B.C.A, MCDBA, MCSD certifications. Dinesh authors the hugely popular Computer Notes blog. Where he writes how-to guides around Computer fundamental , computer software, Computer programming, and web apps.

Dinesh Thakur is a Freelance Writer who helps different clients from all over the globe. Dinesh has written over 500+ blogs, 30+ eBooks, and 10000+ Posts for all types of clients.


For any type of query or something that you think is missing, please feel free to Contact us.


Primary Sidebar

C Programming

C Programming Tutorials

  • C - History
  • C - Anatomy
  • C - Constants
  • C - Identifiers
  • C - Data Types
  • C - Libraries File
  • C - Header Files
  • C - Basic Language
  • C - Data Types Sizes
  • C - Header Files Importance
  • C - Escape Sequences
  • C - Main() Purpose
  • C - Program Procedure
  • C - Control Statements
  • C - Enumeration Constant
  • C - Add numbers
  • C - Return Statement
  • C - Avoid Goto
  • C - Command Line Arguments
  • C - Switch Case
  • C - Switch Case Limitations
  • C - getchar() and putchar()
  • C - Iteration Statements
  • C - Pass by Value and Reference
  • C - Structures and Unions
  • C - Structure
  • C - Dynamic Memory
  • C - Fgets and Fputs Functions
  • C - Gets() and Puts() Functions
  • C - Armstrong Number
  • C - Storage Classes
  • C - Fibonacci Series
  • C - Precision Setting
  • C - const Parameters

C - Variable & It's Type

  • C - Variables
  • C - Variable Lifetime
  • C - Static Variable
  • C - Register Variable
  • C - Global Variables
  • C - Auto Variables
  • C - Local Variables

C - Operator & Expressions

  • C - Operator
  • C - Boolean Operators
  • C - Bitwise Operator
  • C - Arithmetic Operators
  • C - Modulus Operator
  • C - Ternary Operator
  • C - Expressions
  • C - Arithmetic Expressions

C - Array

  • C - Arrays
  • C - Array Types
  • C - Array Characteristics
  • C - Static Arrays
  • C - Global Arrays
  • C - 3D Arrays
  • C - Dynamic Arrays
  • C - Pointer to 3D Arrays
  • C - Array Elements Hold
  • C - Arrays as Function Parameters
  • C - Accessing Matrix Elements
  • C - File Handling
  • C - Matrix Multiplication
  • C - Dynamic Memory Allocation

C - Searching & Sorting

  • C - Data Structures
  • C - Linear Search
  • C - Bubble Sort
  • C - Merge Sort
  • C - Linked List
  • C - Insertion Sort
  • C - Binary Search
  • C - Selection Sort
  • C - Quick Sort

C - Functions

  • C - Functions
  • C - Functions Advantages
  • C - Void Functions
  • C - Function Call
  • C - Default Return Value
  • C - String functions

C - Pointer

  • C - Pointers
  • C - Type Casting Of Pointers
  • C - Pointer Advantages
  • C - Pointers Initialization
  • C - Vectors and Pointers

C - Differences

  • C - C Vs C++
  • C - Formal Args. Vs Actual Args.
  • C - Keywords Vs Identifiers
  • C - Strings Vs Character Arrays
  • C - Address Vs Dereference Operator
  • C - Goto Vs longjmp
  • C - Declaring Vs Defining Variable
  • C - String Vs Array
  • C - Call by Value Vs Reference
  • C - Structure Vs Union
  • C - For Vs While loops
  • C - Compiler Vs Interpreter

C - Programs

  • C Program Standard Deviation
  • C Program Calculate Tax
  • C Program Sum Series
  • C Program Merge Arrays
  • C Program Euclid’s Algorithm
  • C Program Print Weekdays
  • C Program Sum of Digits
  • C Program Print a list
  • C Program Print Pythagorean
  • C Program Quiz program
  • C Program Display Table
  • C Program Print Comma-Separated
  • C Program Prints Prime Numbers
  • C Program for Print Integer
  • C Program Count Number
  • C Program Print Color Name
  • C Program Print Odd Numbers
  • C Program Calculate area
  • C Program for a Menu
  • C Program Add Two Vectors
  • C Program Array Addresses
  • C Program Division by Zero Error
  • C Program Compare two Dates
  • C Program Tower of Hanoi
  • C Program return 3 Numbers
  • C Program for Prime Numbers
  • C Program for Factorial
  • C Program for Palindrome

Other Links

  • C Programming - PDF Version

Footer

Basic Course

  • Computer Fundamental
  • Computer Networking
  • Operating System
  • Database System
  • Computer Graphics
  • Management System
  • Software Engineering
  • Digital Electronics
  • Electronic Commerce
  • Compiler Design
  • Troubleshooting

Programming

  • Java Programming
  • Structured Query (SQL)
  • C Programming
  • C++ Programming
  • Visual Basic
  • Data Structures
  • Struts 2
  • Java Servlet
  • C# Programming
  • Basic Terms
  • Interviews

World Wide Web

  • Internet
  • Java Script
  • HTML Language
  • Cascading Style Sheet
  • Java Server Pages
  • Wordpress
  • PHP
  • Python Tutorial
  • AngularJS
  • Troubleshooting

 About Us |  Contact Us |  FAQ

Dinesh Thakur is a Technology Columinist and founder of Computer Notes.

Copyright © 2025. All Rights Reserved.

APPLY FOR ONLINE JOB IN BIGGEST CRYPTO COMPANIES
APPLY NOW