Last active
December 6, 2018 11:31
-
-
Save karolba/48170cac42804534b347cf49bdfffb98 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#include <stdlib.h> | |
#include "Array.h" | |
struct Array { | |
size_t len; | |
T *data; | |
}; | |
/// Costruction and destruction functions: | |
// funkcja, ktora zwraca Array zaalokowany dynamicznie, z zaalokowana tablica dla zadanego rozmiaru, wartosci elementow tablicy maja byc zerowane | |
Array *constructArray(size_t size) { | |
Array *a = (Array *) malloc(sizeof(Array)); | |
a->len = size; | |
a->data = (T *) malloc(sizeof(T) * size); | |
} | |
// funkcja, ktora zwalnia zaalokowana pamiec na elementy Arraya i ustawia size i date w Array'u odpowiednio na 0 i NULL | |
void destruct(Array *array) { | |
free(array->data); | |
array->len = 0; | |
array->data = NULL; | |
} | |
/// Capasity: | |
// funkcja zwraca ilosc elementow Arraya, zupelnie jak: http://www.cplusplus.com/reference/array/array/size/ | |
size_t size(const Array *array) { | |
return array->len; | |
} | |
// funkcja zwracajaca true jesli mamy do czynienia z pustym Array, zupelnie jak: http://www.cplusplus.com/reference/array/array/empty/ | |
bool empty(const Array *array) { | |
return array->len == 0; | |
} | |
/// Element access functions: | |
// funkcja zwraca wskaznik do elementu Array'a o zadanym indeksie, w razie wyjscia poza tablice zwraca NULL, podobna do: http://www.cplusplus.com/reference/array/array/at/ | |
T *at(Array *array, size_t index) { | |
return (index >= array->len) ? NULL : &array->data[index]; | |
} | |
// zwraca wskaznik na pierwszy element Array'a, podobna do: http://www.cplusplus.com/reference/array/array/front/ | |
T *front(Array *array) { | |
return &array->data[0]; | |
} | |
// jw. ale na ostatni element Array'a, podobna do: www.cplusplus.com/reference/array/array/back/ | |
T *back(Array *array) { | |
return &array->data[array->len - 1]; | |
} | |
// zwraca wskaznik do wewnetrznej tablicy Array'a, podobnie do: http://www.cplusplus.com/reference/array/array/data/ | |
const T *data(Array *array) { | |
return array->data; | |
} | |
/// Modifiers functions: | |
// ustawia wszystkim elementom tablicy zadana wartosc, podobnie do: http://www.cplusplus.com/reference/array/array/fill/ | |
void fill(Array *array, T value) { | |
for(size_t i = 0; i < array->len; i++) { | |
array->data[i] = value; | |
} | |
} | |
// funkcja kopiuje wartosci tablicy na nasze Array, rozmiary tablicy i Array sie zgadzaja | |
void assign(Array *array, const T tab[], size_t tabSize) { | |
for(size_t i = 0; i < tabSize; i++) { | |
array->data[i] = tab[i]; | |
} | |
} | |
static void swap(Array *a, size_t i1, size_t i2) { | |
T tmp = a->data[i2]; | |
a->data[i2] = a->data[i1]; | |
a->data[i1] = tmp; | |
} | |
// funkcja reorganizujaca elementy wg zasady "Ci co pierwsi beda ostatnimi, a ci co ostatni pierwszymi" | |
void reverse(Array *array) { | |
for(size_t i = 0; i < array->len / 2; i++) { | |
swap(array, i, array->len - i - 1); | |
} | |
} | |
/// Optional functions: (tych funkcji nie musza Panstwo implementowac, ale ambitni moga). Pplecam aby funkcje generowaly tekst w formacie: | |
/// array(3) = {1, 2, 3} | |
char *toText(Array *array); | |
void print(Array *array); | |
// funkcja wykonujaca gleboka kopie naszego Array wraz z jego elementami: | |
Array *cloneArray(const Array *array); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment