Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9ea7ae039b |
BIN
munit/munit.o
Normal file
BIN
munit/munit.o
Normal file
Binary file not shown.
114
vector.c
114
vector.c
@@ -1,5 +1,4 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@@ -25,7 +24,21 @@ 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 = 0;
|
||||||
|
v->maxsz = VECTOR_START_SIZE;
|
||||||
|
v->data = xmalloc(ITEMSZ * VECTOR_START_SIZE);
|
||||||
|
|
||||||
|
// Если нужно больше места, перевыделяем
|
||||||
|
if (arrsz > v->maxsz) {
|
||||||
|
v->data = xrealloc(v->data, ITEMSZ * arrsz);
|
||||||
|
v->maxsz = arrsz;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Копируем данные
|
||||||
|
memcpy(v->data, arr, ITEMSZ * arrsz);
|
||||||
|
v->n = arrsz;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -33,9 +46,11 @@ vector_free(ivector *v)
|
|||||||
{
|
{
|
||||||
assert(v);
|
assert(v);
|
||||||
|
|
||||||
|
if (v->data) {
|
||||||
|
xfree(v->data);
|
||||||
|
}
|
||||||
v->n = 0;
|
v->n = 0;
|
||||||
v->maxsz = 0;
|
v->maxsz = 0;
|
||||||
xfree(v->data);
|
|
||||||
v->data = NULL;
|
v->data = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -43,17 +58,14 @@ 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
|
||||||
@@ -61,49 +73,115 @@ 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
|
||||||
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>
|
|
||||||
|
// Проверяем, нужно ли увеличить 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
|
||||||
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 && idx <= v->n);
|
||||||
// <YOURCODE>
|
|
||||||
|
// Проверяем, нужно ли увеличить capacity
|
||||||
|
if (v->n >= v->maxsz) {
|
||||||
|
size_t new_maxsz = v->maxsz * VECTOR_GROW_FACTOR;
|
||||||
|
if (new_maxsz == 0) new_maxsz = VECTOR_START_SIZE;
|
||||||
|
|
||||||
|
v->data = xrealloc(v->data, ITEMSZ * new_maxsz);
|
||||||
|
v->maxsz = new_maxsz;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Сдвигаем элементы вправо
|
||||||
|
for (size_t i = v->n; i > idx; i--) {
|
||||||
|
v->data[i] = v->data[i - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Вставляем новый элемент
|
||||||
|
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);
|
||||||
|
|
||||||
|
// Сдвигаем элементы влево
|
||||||
|
for (size_t i = idx; i < v->n - 1; i++) {
|
||||||
|
v->data[i] = v->data[i + 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
v->n--;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
BIN
vector_test
Executable file
BIN
vector_test
Executable file
Binary file not shown.
@@ -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 }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
BIN
vector_test.o
Normal file
BIN
vector_test.o
Normal file
Binary file not shown.
Reference in New Issue
Block a user