Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5f50565471 |
BIN
munit/munit.o
Normal file
BIN
munit/munit.o
Normal file
Binary file not shown.
60
vector.c
60
vector.c
@@ -25,7 +25,10 @@ void
|
|||||||
vector_initdata(ivector *v, int *arr, size_t arrsz)
|
vector_initdata(ivector *v, int *arr, size_t arrsz)
|
||||||
{
|
{
|
||||||
assert(v && arrsz);
|
assert(v && arrsz);
|
||||||
// <YOURCODE>
|
v->n = arrsz;
|
||||||
|
v->maxsz = (arrsz > VECTOR_START_SIZE) ? arrsz : VECTOR_START_SIZE;
|
||||||
|
v->data = xmalloc(ITEMSZ * v->maxsz);
|
||||||
|
memcpy(v->data, arr, arrsz * ITEMSZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -43,67 +46,94 @@ size_t
|
|||||||
vector_len(const ivector *v)
|
vector_len(const ivector *v)
|
||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
|
return v->n;
|
||||||
// <YOURCODE>
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int *
|
int *
|
||||||
vector_data(const ivector *v)
|
vector_data(const ivector *v)
|
||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
// <YOURCODE>
|
return v->data;
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_resize(ivector *v, int n)
|
vector_resize(ivector *v, int n)
|
||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
|
if (n <= v->maxsz) {
|
||||||
// <YOURCODE>
|
if (n > v->n) {
|
||||||
|
memset(v->data + v->n, 0, (n - v->n) * ITEMSZ);
|
||||||
|
}
|
||||||
|
v->n = n;
|
||||||
|
} else {
|
||||||
|
size_t new_max = v->maxsz;
|
||||||
|
while (new_max < n) {
|
||||||
|
new_max *= VECTOR_GROW_FACTOR;
|
||||||
|
}
|
||||||
|
v->data = xrealloc(v->data, new_max * ITEMSZ);
|
||||||
|
if (n > v->n) {
|
||||||
|
memset(v->data + v->n, 0, (n - v->n) * ITEMSZ);
|
||||||
|
}
|
||||||
|
v->n = n;
|
||||||
|
v->maxsz = new_max;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_set(ivector *v, size_t idx, int val)
|
vector_set(ivector *v, size_t idx, int val)
|
||||||
{
|
{
|
||||||
assert(v && idx < v->n);
|
assert(v && idx < v->n);
|
||||||
// <YOURCODE>
|
v->data[idx] = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
vector_get(const ivector *v, size_t idx)
|
vector_get(const ivector *v, size_t idx)
|
||||||
{
|
{
|
||||||
assert(v && idx < v->n);
|
assert(v && idx < v->n);
|
||||||
// <YOURCODE>
|
return v->data[idx];
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_push(ivector *v, int val)
|
vector_push(ivector *v, int val)
|
||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
// <YOURCODE>
|
if (v->n == v->maxsz) {
|
||||||
|
vector_resize(v, v->n + 1);
|
||||||
|
v->data[v->n - 1] = val;
|
||||||
|
} else {
|
||||||
|
v->data[v->n++] = val;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_pop(ivector *v)
|
vector_pop(ivector *v)
|
||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
// <YOURCODE>
|
if (v->n > 0){
|
||||||
|
v->n--;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_insert(ivector *v, size_t idx, int val)
|
vector_insert(ivector *v, size_t idx, int val)
|
||||||
{
|
{
|
||||||
assert(v && v->n >= idx);
|
assert(v && v->n >= idx);
|
||||||
// <YOURCODE>
|
if (v->n == v->maxsz) {
|
||||||
|
size_t new_max = v->maxsz * VECTOR_GROW_FACTOR;
|
||||||
|
v->data = xrealloc(v->data, new_max * ITEMSZ);
|
||||||
|
v->maxsz = new_max;
|
||||||
|
}
|
||||||
|
memmove(v->data + idx + 1, v->data + idx, (v->n - idx) * ITEMSZ);
|
||||||
|
v->data[idx] = val;
|
||||||
|
v->n++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vector_del(ivector *v, size_t idx)
|
vector_del(ivector *v, size_t idx)
|
||||||
{
|
{
|
||||||
// <YOURCODE>
|
assert(v && idx < v->n);
|
||||||
|
memmove(v->data + idx, v->data + idx + 1, (v->n - idx - 1) * ITEMSZ);
|
||||||
|
v->n--;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
BIN
vector_test
Executable file
BIN
vector_test
Executable file
Binary file not shown.
@@ -162,6 +162,63 @@ test_vector_push_pop(const MunitParameter params[], void * data)
|
|||||||
return MUNIT_OK;
|
return MUNIT_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static MunitResult
|
||||||
|
test_vector_insert(const MunitParameter params[], void* data) {
|
||||||
|
ivector v;
|
||||||
|
vector_init(&v);
|
||||||
|
|
||||||
|
// Ð’Ñ<E28099>тавка в пуÑ<C692>той вектор
|
||||||
|
vector_insert(&v, 0, 1);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 1);
|
||||||
|
munit_assert_int(vector_get(&v, 0), ==, 1);
|
||||||
|
|
||||||
|
// Ð’Ñ<E28099>тавка в начало
|
||||||
|
vector_insert(&v, 0, 2);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 2);
|
||||||
|
munit_assert_int(vector_get(&v, 0), ==, 2);
|
||||||
|
munit_assert_int(vector_get(&v, 1), ==, 1);
|
||||||
|
|
||||||
|
// Ð’Ñ<E28099>тавка в конец
|
||||||
|
vector_insert(&v, 2, 3);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 3);
|
||||||
|
munit_assert_int(vector_get(&v, 2), ==, 3);
|
||||||
|
|
||||||
|
// Ð’Ñ<E28099>тавка в Ñ<>ередину
|
||||||
|
vector_insert(&v, 1, 4);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 4);
|
||||||
|
munit_assert_int(vector_get(&v, 1), ==, 4);
|
||||||
|
munit_assert_int(vector_get(&v, 2), ==, 1);
|
||||||
|
|
||||||
|
vector_free(&v);
|
||||||
|
return MUNIT_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static MunitResult
|
||||||
|
test_vector_del(const MunitParameter params[], void* data) {
|
||||||
|
ivector v;
|
||||||
|
int init[] = {1, 2, 3, 4, 5};
|
||||||
|
vector_initdata(&v, init, ARRSZ(init));
|
||||||
|
|
||||||
|
// Удаление из начала
|
||||||
|
vector_del(&v, 0);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 4);
|
||||||
|
munit_assert_int(vector_get(&v, 0), ==, 2);
|
||||||
|
|
||||||
|
// Удаление из конца
|
||||||
|
vector_del(&v, 3);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 3);
|
||||||
|
munit_assert_int(vector_get(&v, 2), ==, 4);
|
||||||
|
|
||||||
|
// Удаление из Ñ<>ередины
|
||||||
|
vector_del(&v, 1);
|
||||||
|
munit_assert_size(vector_len(&v), ==, 2);
|
||||||
|
munit_assert_int(vector_get(&v, 0), ==, 2);
|
||||||
|
munit_assert_int(vector_get(&v, 1), ==, 4);
|
||||||
|
|
||||||
|
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[] = {
|
||||||
@@ -172,7 +229,8 @@ static MunitTest test_suite_tests[] = {
|
|||||||
TEST_ITEM(test_vector_resize),
|
TEST_ITEM(test_vector_resize),
|
||||||
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 }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
BIN
vector_test.o
Normal file
BIN
vector_test.o
Normal file
Binary file not shown.
Reference in New Issue
Block a user