#include<stdio.h>
#define N 5
#define M (N * 2)
int main()
{
int a[N], b[N], c[M], i, index = 0;
printf("Enter %d integer numbers, for first array\n", N);
for(i = 0; i < N; i++)
scanf("%d", &a[i]);
printf("Enter %d integer numbers, for second array\n", N);
for(i = 0; i < N; i++)
scanf("%d", &b[i]);
printf("\nMerging a[%d] and b[%d] to form c[%d] ..\n", N, N, M);
for(i = 0; i < N; i++)
c[index++] = a[i];
for(i = 0; i < N; i++)
c[index++] = b[i];
printf("\nElements of c[%d] is ..\n", M);
for(i = 0; i < M; i++)
printf("%d\n", c[i]);
return 0;
}
Output: Enter 5 integer numbers, for first array 0 9 8 7 6 Enter 5 integer numbers, for second array 5 4 3 2 1
Merging a[5] and b[5] to form c[10] ..
Elements of c[10] is .. 0 9 8 7 6 5 4 3 2 1
Logic To Concatenate Two Array To Form Third Array
Here size of array a and b are same, so the for loops are same to accept elements of array a and b. We initialize variable index to 0. We write a for loop and iterate from 0 to 4, and copy the individual elements of array a to array c. Here index of array a and c varies from 0 to 4.
In the second for loop again we iterate the for loop from 0 to 4. This time value of variable index varies from 5 to 9, where as value of index of variable b varies from 0 to 4. So the individual elements of array b are copied to array c from index 5 to 9.
Method 2: Arrays with different size
#include<stdio.h>
#define N1 5
#define N2 6
#define M (N1 + N2)
int main()
{
int a[N1], b[N2], c[M], i, index = 0;
printf("Enter %d integer numbers, for first array\n", N1);
for(i = 0; i < N1; i++)
scanf("%d", &a[i]);
printf("Enter %d integer numbers, for second array\n", N2);
for(i = 0; i < N2; i++)
scanf("%d", &b[i]);
printf("\nMerging a[%d] and b[%d] to form c[%d] ..\n", N1, N2, M);
for(i = 0; i < N1; i++)
c[index++] = a[i];
for(i = 0; i < N2; i++)
c[index++] = b[i];
printf("\nElements of c[%d] is ..\n", M);
for(i = 0; i < M; i++)
printf("%d\n", c[i]);
return 0;
}
Output: Enter 5 integer numbers, for first array 0 1 2 3 4 Enter 6 integer numbers, for second array 5 6 7 8 9 10
Merging a[5] and b[6] to form c[11] ..
Elements of c[11] is .. 0 1 2 3 4 5 6 7 8 9 10
Here the logic to concatenate array elements is same, but only difference is the size of array variable a and b. So we need to be careful while writing conditions in for loop.
Enter 5 unique integer numbers 5 2 6 4 3 First Big: 6 Second Big: 5
Important Note: This code only works for inputs which has unique integer numbers. If there are duplicate integer numbers which is biggest in the array, then it’ll show the same number for both first and second biggest element. We can fix it, but it’s out of scope of this problem statement. Just know the limitation of this code.
Ex: a[5] = {2, 4, 5, 3, 5}; In this case, both first big and second big will have value 5.
Video Tutorial: C Program To Find First and Second Biggest Element In An Array
In both the cases the logic is same. If a[0] is greater than a[1], then value present at a[0] will be assigned to fbig, and a[1] will be assigned to sbig. If a[0] is not greater than a[1], then a[1] will be assigned to fbig and a[0] will be assigned to sbig.
for loop Since both a[0] and a[1] are already sorted out, the comparison must start from a[2]. So we initialize the loop counter variable i to 2 and loop through until i < N and for each iteration we increment the value of i by 1.
Inside for loop If value of fbig is less than the fetched element of the array, then we transfer the value of fbig to sbig and assign the new array element value to fbig.
Else if, the fetched element of the array is less than fbig but greater than sbig, then we assign the value of the array element to sbig.
In this video tutorial lets learn about Designated Initializers in arrays.
C99 introduced the concept of designated initializers. These allow you to specify which elements of an array, structure or union are to be initialized by the values following.
We’ll look at using Designated Initializers for structures and unions in separate video tutorial, for now lets see how we can use it for arrays in C programming language.
When you have a very large array and most of the elements of array are zeros and only couple of elements are non-zeros. In that case, you can use designators to initialize particular elements of an array to non-zero values.
Video Tutorial: Designated Initializers In Array: C Program
Source Code: Designated Initializers In Array: C Program
1. Display array Elements
#include<stdio.h>
int main()
{
int a[5] = {0, 0, 1, 0, 8}, i;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 0 0 1 0 8
We use simple for loop to loop through all the elements of an array and display it on to the console window.
2. Garbage values inside uninitialized array
#include<stdio.h>
int main()
{
int a[5], i;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 6356864 4200750 4200656 46 8
If array elements are not initialized it’ll have garbage values. Even if you initialize one element in that array, the rest of the elements will be automatically initialized to zero. And even if you simply have a equal sign and opening and closing curly braces in front of array variable, the compiler will assign zero to all the elements.
3. All zeros as array element
#include<stdio.h>
int main()
{
int a[5] = {}, i;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 0 0 0 0 0
Since we’ve opening and closing flower bracket or curly brackets in front of array declaration, compiler will automatically assign zeros as array elements.
4. Overwrite the values of array element
#include<stdio.h>
int main()
{
int a[5], i;
a[2] = 1;
a[4] = 8;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 6356864 4200766 1 46 8
From source code 2 above, we know that uninitialized arrays will have garbage values inside it. We are over-writing the garbage values at index 2 and index 4 with 1 and 8 respectively. So except for index 2 and 4 all other spots are filled with garbage values.
So this fixes our issue. Since we’ve empty opening and closing curly braces after declaring array variable, all the elements of array will be automatically initialized to 0.
After that we overwrite the values at index 2 and 4 with 1 and 8.
Now lets make use of Designated Initializers
For arrays with large size we need to use Designated Initializers. Because we can’t individually assign values by overwriting it. It’ll take lot of space in your source code. To avoid that, and to write it in single line of code, we make use of Designated Initializers.
As you can see the designator [4] appears before the designator [2], but still it doesn’t change anything with the output.
8. Designated Initializers: Alternate Syntax
#include<stdio.h>
int main()
{
// {0, 0, 1, 0, 8}
int a[5] = {[2]1, [4]8}, i;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 0 0 1 0 8
As you can see in above source code, we are not using equal sign(=) to assign value to designators. And it’s valid syntax.
9. Designated Initializers: Mixed Syntax
#include<stdio.h>
int main()
{
// {0, 0, 1, 0, 8}
int a[5] = {[2]1, [4] = 8}, i;
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: 0 0 1 0 8
You can see that we’ve used both syntax to initialize value to particular index of the array. i.e., [2]1 and [4] = 8. Even if we mix both these syntax, it works and its perfectly valid syntax in C standard.
10. Designated Initializers: And dynamic array size
If we don’t mention length or size of the array explicitly, then the compiler will assign the length or size of the array from the largest designator in the list.
Note: Since the largest designator is 10 in above source code, which must be N – 1 i.e, 11 – 1 = 10. So array size is 11. OR since index starts from 0, and the largest designator is 10. i.e., 0 to 10, which means 11 elements in an array.
11. Designated Initializers: Designators and normal initializers
Here we make use of designators to initialize range of elements. Syntax is [first … last] = value. i.e., the first index to start initializing and the last index to end the initialization. In between these two indexes there are 3 dots.
13. Designated Initializers: initialize range of elements in an array, with mixed syntax
In above source code you can see mixed syntax to initialize elements of the array. i.e., [1 … 3] = 2 is valid, [4 … 6]3 is valid too, and index 7 is assigned a value of 5 directly. All other indexes will have a value of zero.
Note: This is a very simple program but still a very important one, because we’ll be using some form of logic to print elements of an array. So better we know ins and outs of printing array elements in whichever order the program demands. So please pay attention to the logic.
Video Tutorial: C Program To Print Elements of Array In Reverse Order
Source Code: C Program To Print Elements of Array In Reverse Order
#include<stdio.h>
int main()
{
int a[5], i;
printf("Enter 5 integer numbers\n");
for(i = 0; i < 5; i++)
scanf("%d", &a[i]);
printf("Array elements are:\n");
for(i = 4; i >= 0; i--)
printf("%d\n", a[i]);
return 0;
}
Output: Enter 5 integer numbers 1 2 3 4 5 Array elements are: 5 4 3 2 1
Since the array size is 5, the last index of the array will be (5-1) which is 4. So we initialize i to 4, and keep decrementing the value of i by 1 for each iteration of the for loop. Control exits for loop once i value is equal to 0. In arrays the index starts from 0. Inside for loop, for each iteration, we print the value of i.
#include<stdio.h>
#define N 5
int main()
{
int a[N], i;
printf("Enter %d integer numbers\n", N);
for(i = 0; i < N; i++)
scanf("%d", &a[i]);
printf("Array elements are:\n");
for(i = N-1; i >= 0; i--)
printf("%d\n", a[i]);
return 0;
}
Output: Enter 5 integer numbers 1 2 3 4 5 Array elements are: 5 4 3 2 1
Here we initialize value of i to the last index of the array, which is N-1. We iterate through the for loop until i value is 0(which is the first index of the array), for each iteration of the for loop we decrement the value of i by 1. Inside for loop we print the value of a[i].
Lets look at basics of arrays in C programming language. We’ve already covered a lot of stuffs about arrays in Introduction To Arrays: C Programming Language. In this video tutorial we’ll look at some specific things about arrays which we use often.
Each cell in array occupies memory space depending upon its data type. Int and float occupies 4 bytes. Char occupies 1 byte. Double occupies 8 bytes. Also remember, size of data type is machine dependent.
Initializing and Accessing Array Elements
#include<stdio.h>
int main()
{
int a[5], i;
printf("Enter 5 integer numbers\n");
for(i = 0; i < 5; i++)
scanf("%d", &a[i]);
printf("Array elements are: \n");
for(i = 0; i < 5; i++)
printf("%d\n", a[i]);
return 0;
}
Output: Enter 5 integer numbers 1 2 3 4 5 Array elements are: 1 2 3 4 5