Compare commits

1 Commits

Author SHA1 Message Date
Ваше Имя
2558f9a414 всякое разное 2025-11-15 04:36:38 -05:00

115
vector.c
View File

@@ -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>
@@ -7,107 +6,153 @@
#include "vector.h" #include "vector.h"
#include "util.h" #include "util.h"
#define VECTOR_START_SIZE 8 #define VECTOR_START_SIZE 8
#define VECTOR_GROW_FACTOR 2 #define VECTOR_GROW_FACTOR 2
#define ITEMSZ sizeof(int) #define ITEMSZ sizeof(int)
void void
vector_init(ivector *v) vector_init(ivector *v)
{ {
assert(v); assert(v);
v->n = 0; v->n = 0;
v->maxsz = VECTOR_START_SIZE; v->maxsz = VECTOR_START_SIZE;
v->data = xmalloc(ITEMSZ * VECTOR_START_SIZE); v->data = xmalloc(ITEMSZ * VECTOR_START_SIZE);
} }
void 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, ITEMSZ * arrsz);
} }
void void
vector_free(ivector *v) vector_free(ivector *v)
{ {
assert(v); assert(v);
v->n = 0; v->n = 0;
v->maxsz = 0; v->maxsz = 0;
xfree(v->data); xfree(v->data);
v->data = NULL; v->data = NULL;
} }
size_t size_t
vector_len(const ivector *v) vector_len(const ivector *v)
{ {
assert(v); assert(v);
// <YOURCODE> return v->n;
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);
// <YOURCODE> if (n <= v->maxsz) {
v->n = n;
return;
}
size_t new_maxsz = v->maxsz;
while (new_maxsz < n) {
new_maxsz *= VECTOR_GROW_FACTOR;
}
v->data = xrealloc(v->data, ITEMSZ * new_maxsz);
for (size_t i = v->n; i < (size_t)n; i++) {
v->data[i] = 0;
}
v->maxsz = new_maxsz;
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>
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--;
}
} }
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_maxsz = v->maxsz * VECTOR_GROW_FACTOR;
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
vector_clear(ivector *v) vector_clear(ivector *v)
{ {
vector_resize(v, 0); vector_resize(v, 0);
} }