2018-03-20 07:09:22 +08:00
|
|
|
/*
|
|
|
|
* CArray.c
|
|
|
|
*
|
|
|
|
* Author: Leonardo Vencovsky
|
|
|
|
* Created on 19/03/2018
|
|
|
|
*
|
|
|
|
* Modified by: Leonardo Vencovsky
|
|
|
|
* Last modified: 19/03/2018
|
|
|
|
*
|
|
|
|
* Array Implementations in C
|
|
|
|
*
|
|
|
|
* Compiled in Visual Studio 2017
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
/*
|
|
|
|
Return Codes
|
2018-03-20 07:09:22 +08:00
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
-1 - Array Erased
|
|
|
|
0 - Success
|
|
|
|
1 - Invalid Position
|
|
|
|
2 - Position already initialized (use update function)
|
|
|
|
3 - Position not initialized (use insert function)
|
|
|
|
4 - Position already empty
|
|
|
|
5 - Array is full
|
2018-03-20 07:09:22 +08:00
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
*/
|
2018-03-20 07:09:22 +08:00
|
|
|
|
2021-01-25 13:04:33 +08:00
|
|
|
#include "carray.h"
|
2018-03-20 07:09:22 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2018-07-19 22:23:32 +08:00
|
|
|
#include <time.h>
|
2018-03-20 07:09:22 +08:00
|
|
|
|
|
|
|
void swap(CArray *array, int position1, int position2);
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
CArray *getCArray(int size)
|
2018-03-20 07:09:22 +08:00
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
CArray *array = (CArray *)malloc(sizeof(CArray));
|
|
|
|
array->array = (int *)malloc(sizeof(int) * size);
|
|
|
|
array->size = size;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < size; i++)
|
|
|
|
{
|
|
|
|
array->array[i] = 0;
|
|
|
|
}
|
|
|
|
return array;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int insertValueCArray(CArray *array, int position, int value)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
if (position >= 0 && position < array->size)
|
|
|
|
{
|
|
|
|
if (array->array[position] == 0)
|
|
|
|
{
|
|
|
|
array->array[position] = value;
|
|
|
|
return SUCCESS;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return POSITION_INIT;
|
|
|
|
}
|
|
|
|
return INVALID_POSITION;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int removeValueCArray(CArray *array, int position)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
if (position >= 0 && position < array->size)
|
|
|
|
{
|
|
|
|
if (array->array[position] != 0)
|
|
|
|
{
|
|
|
|
array->array[position] = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return POSITION_EMPTY;
|
|
|
|
}
|
|
|
|
return INVALID_POSITION;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int pushValueCArray(CArray *array, int value)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
int ok = 0;
|
|
|
|
for (i = 0; i < array->size; i++)
|
|
|
|
{
|
|
|
|
if (array->array[i] == 0)
|
|
|
|
{
|
|
|
|
array->array[i] = value;
|
|
|
|
ok = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (ok == 1)
|
|
|
|
return SUCCESS;
|
|
|
|
else
|
|
|
|
return ARRAY_FULL;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int updateValueCArray(CArray *array, int position, int value)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
if (position >= 0 && position < array->size)
|
|
|
|
{
|
|
|
|
if (array->array[position] != 0)
|
|
|
|
{
|
2022-01-15 04:04:55 +08:00
|
|
|
array->array[position] = value;
|
|
|
|
return SUCCESS;
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
2018-07-19 22:23:32 +08:00
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
else
|
|
|
|
return POSITION_NOT_INIT;
|
|
|
|
}
|
|
|
|
return INVALID_POSITION;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int eraseCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
for (i = 0; i < array->size; i++)
|
|
|
|
{
|
|
|
|
array->array[i] = 0;
|
|
|
|
}
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int switchValuesCArray(CArray *array, int position1, int position2)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
if (position1 >= 0 && position1 < array->size && position2 >= 0 &&
|
|
|
|
position2 < array->size)
|
|
|
|
{
|
|
|
|
int temp = array->array[position1];
|
|
|
|
array->array[position1] = array->array[position2];
|
|
|
|
array->array[position2] = temp;
|
2022-09-30 16:50:08 +08:00
|
|
|
return SUCCESS;
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
|
|
|
return INVALID_POSITION;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int reverseCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
for (i = 0; i < array->size / 2; i++)
|
|
|
|
{
|
|
|
|
swap(array, i, array->size - i - 1);
|
|
|
|
}
|
|
|
|
return SUCCESS;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int displayCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
printf("\nC ARRAY\n");
|
|
|
|
for (i = 0; i < array->size; i++)
|
|
|
|
{
|
|
|
|
printf("%d ", array->array[i]);
|
|
|
|
}
|
|
|
|
printf("\n");
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int blenderCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
srand(time(NULL) * array->size);
|
|
|
|
int i;
|
|
|
|
int total = array->size * 100;
|
|
|
|
for (i = 0; i < total; i++)
|
|
|
|
{
|
|
|
|
swap(array, rand() % array->size, rand() % array->size);
|
|
|
|
}
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
CArray *getCopyCArray(CArray *arr)
|
2018-03-20 07:09:22 +08:00
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
CArray *array = (CArray *)malloc(sizeof(CArray));
|
|
|
|
array->array = (int *)malloc(sizeof(int) * arr->size);
|
|
|
|
array->size = arr->size;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < arr->size; i++)
|
|
|
|
{
|
|
|
|
array->array[i] = arr->array[i];
|
|
|
|
}
|
|
|
|
return array;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void swap(CArray *array, int position1, int position2)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int temp = array->array[position1];
|
|
|
|
array->array[position1] = array->array[position2];
|
|
|
|
array->array[position2] = temp;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int bubbleSortCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i, j;
|
|
|
|
for (i = 0; i < array->size - 1; i++)
|
|
|
|
{
|
|
|
|
for (j = 0; j < array->size - i - 1; j++)
|
|
|
|
{
|
|
|
|
if (array->array[j] > array->array[j + 1])
|
|
|
|
{
|
|
|
|
swap(array, j, j + 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int selectionSortCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i, j, min;
|
|
|
|
for (i = 0; i < array->size - 1; i++)
|
|
|
|
{
|
|
|
|
min = i;
|
|
|
|
for (j = i + 1; j < array->size; j++)
|
|
|
|
if (array->array[j] < array->array[min])
|
|
|
|
min = j;
|
|
|
|
swap(array, min, i);
|
|
|
|
}
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int insertionSortCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i, j, num;
|
|
|
|
for (i = 1; i < array->size; i++)
|
|
|
|
{
|
|
|
|
num = array->array[i];
|
|
|
|
j = i - 1;
|
|
|
|
while (j >= 0 && array->array[j] > num)
|
|
|
|
{
|
|
|
|
array->array[j + 1] = array->array[j];
|
|
|
|
j--;
|
|
|
|
}
|
|
|
|
array->array[j + 1] = num;
|
|
|
|
}
|
|
|
|
return 0;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int valueOcurranceCArray(CArray *array, int value)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i, total = 0;
|
|
|
|
for (i = 0; i < array->size; i++)
|
|
|
|
{
|
|
|
|
if (array->array[i] == value)
|
|
|
|
total++;
|
|
|
|
}
|
|
|
|
return total;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
CArray *valuePositionsCArray(CArray *array, int value)
|
2018-03-20 07:09:22 +08:00
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i, j = 0;
|
|
|
|
int total = valueOcurranceCArray(array, value);
|
|
|
|
CArray *resultArray = getCArray(total);
|
|
|
|
for (i = 0; i < array->size; i++)
|
|
|
|
{
|
|
|
|
if (array->array[i] == value)
|
|
|
|
{
|
|
|
|
// Hopefully this won't overflow
|
|
|
|
resultArray->array[j] = i;
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return resultArray;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int findMinCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
int min = array->array[0];
|
|
|
|
for (i = 1; i < array->size; i++)
|
|
|
|
{
|
|
|
|
if (array->array[i] < min)
|
|
|
|
{
|
|
|
|
min = array->array[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return min;
|
2018-03-20 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int findMaxCArray(CArray *array)
|
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
|
|
|
int max = array->array[0];
|
|
|
|
for (i = 1; i < array->size; i++)
|
|
|
|
{
|
|
|
|
if (array->array[i] > max)
|
|
|
|
{
|
|
|
|
max = array->array[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return max;
|
2018-07-19 22:23:32 +08:00
|
|
|
}
|