Compare commits

4 Commits

Author SHA1 Message Date
Artem
1fc304edf8 all test OK 2025-11-15 05:16:20 -05:00
Artem
6cff6d953e vector_test.c done first ver 2025-11-15 05:14:20 -05:00
Artem
7aa1a963e5 cp from PAX 2025-11-15 05:08:30 -05:00
dfdfd
5c126c1b61 vector.c is done first ver 2025-11-15 04:41:03 -05:00
2 changed files with 137 additions and 11 deletions

View File

@@ -26,6 +26,10 @@ vector_initdata(ivector *v, int *arr, size_t arrsz)
{ {
assert(v && arrsz); assert(v && arrsz);
// <YOURCODE> // <YOURCODE>
v->n = arrsz;
v->maxsz = arrsz;
v->data = xmalloc(ITEMSZ * arrsz);
memcpy (v->data, arr, ITEMSZ * arrsz);
} }
void void
@@ -45,7 +49,7 @@ vector_len(const ivector *v)
assert(v); assert(v);
// <YOURCODE> // <YOURCODE>
return 0; return v->n;
} }
int * int *
@@ -53,7 +57,7 @@ vector_data(const ivector *v)
{ {
assert(v); assert(v);
// <YOURCODE> // <YOURCODE>
return NULL; return v->data;
} }
void void
@@ -61,7 +65,37 @@ vector_resize(ivector *v, int n)
{ {
assert(v); assert(v);
// <YOURCODE> if (n > v->maxsz) {
// Увеличиваем capacity
size_t new_maxsz = v->maxsz;
while (new_maxsz < n) {
new_maxsz *= VECTOR_GROW_FACTOR;
}
// Сохраняем старый указатель
int *old_data = v->data;
v->data = xmalloc(ITEMSZ * new_maxsz);
// Копируем старые данные
if (old_data) {
memcpy(v->data, old_data, ITEMSZ * v->n);
xfree(old_data);
}
// Обнуляем новую память
for (size_t i = v->n; i < new_maxsz; i++) {
v->data[i] = 0;
}
v->maxsz = new_maxsz;
} else if (n > v->n) {
// Если увеличиваем размер в пределах capacity, обнуляем новые элементы
for (size_t i = v->n; i < n; i++) {
v->data[i] = 0;
}
}
v->n = n;
} }
void void
@@ -69,6 +103,7 @@ vector_set(ivector *v, size_t idx, int val)
{ {
assert(v && idx < v->n); assert(v && idx < v->n);
// <YOURCODE> // <YOURCODE>
v->data[idx] = val;
} }
int int
@@ -76,21 +111,35 @@ vector_get(const ivector *v, size_t idx)
{ {
assert(v && idx < v->n); assert(v && idx < v->n);
// <YOURCODE> // <YOURCODE>
return 0; return v->data[idx];
} }
void void
vector_push(ivector *v, int val) vector_push(ivector *v, int val)
{ {
assert(v); assert(v);
// <YOURCODE>
// Проверяем, нужно ли увеличить capacity
if (v->n >= v->maxsz) {
size_t new_maxsz = v->maxsz * VECTOR_GROW_FACTOR;
v->data = xrealloc(v->data, ITEMSZ * new_maxsz);
v->maxsz = new_maxsz;
}
// Добавляем элемент
v->data[v->n] = val;
v->n++;
} }
void void
vector_pop(ivector *v) vector_pop(ivector *v)
{ {
assert(v); assert(v);
// <YOURCODE>
if (v->n > 0) {
v->n--;
}
// Если вектор пуст, ничего не делаем (без assert)
} }
void void
@@ -98,12 +147,26 @@ vector_insert(ivector *v, size_t idx, int val)
{ {
assert(v && v->n >= idx); assert(v && v->n >= idx);
// <YOURCODE> // <YOURCODE>
if(v->n == v->maxsz){
size_t new_maxsz = v->maxsz * VECTOR_GROW_FACTOR;
if (new_maxsz==0)
new_maxsz = VECTOR_START_SIZE;
vector_resize (v, (int)new_maxsz);
}
memmove(v->data+idx+1, v->data+idx, ITEMSZ * (v->n-idx));
v->data[idx]=val;
v->n++;
} }
void void
vector_del(ivector *v, size_t idx) vector_del(ivector *v, size_t idx)
{ {
// <YOURCODE> // <YOURCODE>
memmove(v->data+idx, v->data+idx+1, ITEMSZ * (v->n-1-idx));
v->n--;
} }
void void

View File

@@ -77,7 +77,6 @@ test_vector_resize(const MunitParameter params[], void * data)
munit_assert_size(v.n, <=, v.maxsz); munit_assert_size(v.n, <=, v.maxsz);
// Try to check that new memory is really zeroed
i = ARRSZ(arr); i = ARRSZ(arr);
p = vector_data(&v); p = vector_data(&v);
for (; i < 16; i++) { for (; i < 16; i++) {
@@ -107,7 +106,6 @@ test_vector_set_get(const MunitParameter params[], void * data)
for (i = 0; i < vector_len(&v); i++) { for (i = 0; i < vector_len(&v); i++) {
int item = vector_get(&v, i); int item = vector_get(&v, i);
munit_assert_int(item, ==, i); munit_assert_int(item, ==, i);
//double check with raw pointer
munit_assert_int(p[i], ==, i); munit_assert_int(p[i], ==, i);
} }
@@ -132,7 +130,6 @@ test_vector_push_pop(const MunitParameter params[], void * data)
} }
munit_assert_size(vector_len(&v), ==, ARRSZ(arr)); munit_assert_size(vector_len(&v), ==, ARRSZ(arr));
// test vector_get
for (i = 0; i < ARRSZ(arr); i++) { for (i = 0; i < ARRSZ(arr); i++) {
tmp = vector_get(&v, i); tmp = vector_get(&v, i);
munit_assert_int(tmp, ==, arr[i]); munit_assert_int(tmp, ==, arr[i]);
@@ -149,19 +146,82 @@ test_vector_push_pop(const MunitParameter params[], void * data)
} }
munit_assert_size(vector_len(&v), ==, ARRSZ(arr) - 2); munit_assert_size(vector_len(&v), ==, ARRSZ(arr) - 2);
//test vector_pop underflow
for (i = 0; i < ARRSZ(arr); i++) { for (i = 0; i < ARRSZ(arr); i++) {
vector_pop(&v); vector_pop(&v);
} }
munit_assert_size(vector_len(&v), ==, 0); munit_assert_size(vector_len(&v), ==, 0);
//test vector_pop
vector_free(&v); vector_free(&v);
return MUNIT_OK; return MUNIT_OK;
} }
static MunitResult
test_vector_insert(const MunitParameter params[], void * data)
{
ivector v;
vector_init(&v);
vector_insert(&v, 0, 100);
munit_assert_size(vector_len(&v), ==, 1);
munit_assert_int(vector_get(&v, 0), ==, 100);
vector_insert(&v, 0, 200);
munit_assert_size(vector_len(&v), ==, 2);
munit_assert_int(vector_get(&v, 0), ==, 200);
munit_assert_int(vector_get(&v, 1), ==, 100);
vector_insert(&v, 2, 300);
munit_assert_size(vector_len(&v), ==, 3);
munit_assert_int(vector_get(&v, 2), ==, 300);
vector_insert(&v, 1, 400);
munit_assert_size(vector_len(&v), ==, 4);
munit_assert_int(vector_get(&v, 0), ==, 200);
munit_assert_int(vector_get(&v, 1), ==, 400);
munit_assert_int(vector_get(&v, 2), ==, 100);
munit_assert_int(vector_get(&v, 3), ==, 300);
vector_free(&v);
return MUNIT_OK;
}
static MunitResult
test_vector_del(const MunitParameter params[], void * data)
{
ivector v;
vector_init(&v);
int i;
for (i = 0; i < 5; i++) {
vector_push(&v, i * 10);
}
munit_assert_size(vector_len(&v), ==, 5);
vector_del(&v, 0);
munit_assert_size(vector_len(&v), ==, 4);
munit_assert_int(vector_get(&v, 0), ==, 10);
vector_del(&v, 3);
munit_assert_size(vector_len(&v), ==, 3);
munit_assert_int(vector_get(&v, 0), ==, 10);
munit_assert_int(vector_get(&v, 1), ==, 20);
munit_assert_int(vector_get(&v, 2), ==, 30);
vector_del(&v, 1);
munit_assert_size(vector_len(&v), ==, 2);
munit_assert_int(vector_get(&v, 0), ==, 10);
munit_assert_int(vector_get(&v, 1), ==, 30);
vector_del(&v, 0);
vector_del(&v, 0);
munit_assert_size(vector_len(&v), ==, 0);
vector_free(&v);
return MUNIT_OK;
}
#define TEST_ITEM(func) {#func, func, NULL, NULL, MUNIT_TEST_OPTION_NONE } #define TEST_ITEM(func) {#func, func, NULL, NULL, MUNIT_TEST_OPTION_NONE }
static MunitTest test_suite_tests[] = { static MunitTest test_suite_tests[] = {
@@ -173,6 +233,9 @@ static MunitTest test_suite_tests[] = {
TEST_ITEM(test_vector_set_get), TEST_ITEM(test_vector_set_get),
TEST_ITEM(test_vector_push_pop), TEST_ITEM(test_vector_push_pop),
TEST_ITEM(test_vector_insert),
TEST_ITEM(test_vector_del),
{ NULL, NULL, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL } { NULL, NULL, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL }
}; };