forked from 131/lab5_ivec
ya chort
This commit is contained in:
114
vector.c
114
vector.c
@@ -1,5 +1,4 @@
|
||||
#include <assert.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
@@ -25,7 +24,21 @@ void
|
||||
vector_initdata(ivector *v, int *arr, size_t 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
|
||||
@@ -33,9 +46,11 @@ vector_free(ivector *v)
|
||||
{
|
||||
assert(v);
|
||||
|
||||
if (v->data) {
|
||||
xfree(v->data);
|
||||
}
|
||||
v->n = 0;
|
||||
v->maxsz = 0;
|
||||
xfree(v->data);
|
||||
v->data = NULL;
|
||||
}
|
||||
|
||||
@@ -43,17 +58,14 @@ size_t
|
||||
vector_len(const ivector *v)
|
||||
{
|
||||
assert(v);
|
||||
|
||||
// <YOURCODE>
|
||||
return 0;
|
||||
return v->n;
|
||||
}
|
||||
|
||||
int *
|
||||
vector_data(const ivector *v)
|
||||
{
|
||||
assert(v);
|
||||
// <YOURCODE>
|
||||
return NULL;
|
||||
return v->data;
|
||||
}
|
||||
|
||||
void
|
||||
@@ -61,49 +73,115 @@ vector_resize(ivector *v, int n)
|
||||
{
|
||||
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
|
||||
vector_set(ivector *v, size_t idx, int val)
|
||||
{
|
||||
assert(v && idx < v->n);
|
||||
// <YOURCODE>
|
||||
v->data[idx] = val;
|
||||
}
|
||||
|
||||
int
|
||||
vector_get(const ivector *v, size_t idx)
|
||||
{
|
||||
assert(v && idx < v->n);
|
||||
// <YOURCODE>
|
||||
return 0;
|
||||
return v->data[idx];
|
||||
}
|
||||
|
||||
void
|
||||
vector_push(ivector *v, int val)
|
||||
{
|
||||
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
|
||||
vector_pop(ivector *v)
|
||||
{
|
||||
assert(v);
|
||||
// <YOURCODE>
|
||||
|
||||
if (v->n > 0) {
|
||||
v->n--;
|
||||
}
|
||||
// Если вектор пуст, ничего не делаем (без assert)
|
||||
}
|
||||
|
||||
void
|
||||
vector_insert(ivector *v, size_t idx, int val)
|
||||
{
|
||||
assert(v && v->n >= idx);
|
||||
// <YOURCODE>
|
||||
assert(v && idx <= v->n);
|
||||
|
||||
// Проверяем, нужно ли увеличить 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
|
||||
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
|
||||
|
||||
Reference in New Issue
Block a user