Slip 3_1 : Sort a random array of n integers (accept the value of n from user) in ascending order by using insertion sort algorithm.
Solution :
/* Insertion sort on random nos */
#include<stdio.h>
int main()
{
int a[10],i,j,n,key;
printf("Enter how many numbers: ");
scanf("%d",&n);
for(i=0; i<n; i++)
{
a[i]=rand()%100;
}
printf("\n Before sorting array is ");
for(i=0;i<n;i++)
{
printf("%d ",a[i]);
}
for(i=1; i<n; i++)
{
key = a[i];
for(j=i-1; j>=0; j--)
{
if(a[j] > key)
{
a[j+1]=a[j];
}
else
break;
}
a[j+1]=key;
}
printf("\nAfter sort array is: ");
for(i=0; i<n; i++)
{
printf("%d ",a[i]);
}
}
/* Insertion sort on random nos */
#include<stdio.h>
int main()
{
int a[10],i,j,n,key;
printf("Enter how many numbers: ");
scanf("%d",&n);
for(i=0; i<n; i++)
{
a[i]=rand()%100;
}
printf("\n Before sorting array is ");
for(i=0;i<n;i++)
{
printf("%d ",a[i]);
}
for(i=1; i<n; i++)
{
key = a[i];
for(j=i-1; j>=0; j--)
{
if(a[j] > key)
{
a[j+1]=a[j];
}
else
break;
}
a[j+1]=key;
}
printf("\nAfter sort array is: ");
for(i=0; i<n; i++)
{
printf("%d ",a[i]);
}
}
Comments
Post a Comment