「malloc」と「realloc」を使用して昇順リストを作成する関数を作成しようとしています。
構造は次のとおりです。
struct sorted_dyn_array {
int *array;
int length;
int capacity;
};
ヒープに割り当てられた sorted_dyn_array 構造体へのポインタを返します
const int BUFFER_INIT_SIZE = 5;
const int KEY_NOT_FOUND = -1;
struct sorted_dyn_array *arr_create(void) {
struct sorted_dyn_array *new_arr = malloc(sizeof (struct sorted_dyn_array));
new_arr->array = malloc(sizeof (int) * BUFFER_INIT_SIZE);
new_arr->length = 0;
new_arr->capacity = 5;
return new_arr;
}
空きメモリ:
void free_arr(struct sorted_dyn_array *arr) {
free(arr->buffer);
free(arr);
}
int arr_length(struct sorted_dyn_array * arr) {
return arr->length;
}
int arr_capacity(struct sorted_dyn_array *arr) {
return arr->capacity;
}
二分探索を使用して、次の数字の位置を見つけます。
int find_pos(int item, int arr[], int len) {
int low = 0;
int high = len-1;
if (arr[0] >= item) {
return 0;
}
if(arr[0] < item) {
return KEY_NOT_FOUND;
}
while (low <= high) {
int mid = low + (high - low) / 2;
if (arr[mid] == item) {
return mid;
} else if (arr[mid] < item) {
low = mid + 1;
} else {
high = mid - 1;
}
if(arr[high] < item) {
return high;
}
}
return KEY_NOT_FOUND;
}
int arr_find_successor(struct sorted_dyn_array *arr, int k) {
int len = arr_length(arr);
return find_pos(k,arr->buffer,len);
}
数値を挿入します。既にリストにある場合は、false を返します。それ以外の場合は、リストに数値を挿入して true を返します
bool arr_insert(struct sorted_dyn_array *arr, int k) {
int pos = arr_find_successor(arr,k);
if(arr_length(arr) == arr_capacity(arr)) {
arr->capacity *= 2;
arr->array = realloc(arr->buffer, sizeof(int) * arr->capacity);// realloc if the length exceed the capacity
}
if (pos == KEY_NOT_FOUND) {// If the number is greater than all the number in array,put it at the end
int l = arr->length;
arr->array[l] = k;
arr->length++;
}
if (pos != KEY_NOT_FOUND){
for (int c = arr->length - 1; c >= pos; c--)
arr->array[c+1] = array->array[c];
arr->array[pos] = k;
arr->length++;
}
return true;
}
主な機能:
int main () {
struct sorted_dyn_array *myarray = arr_create();
int next = 0;
while (scanf("%d",&next) == 1) {
int next_item = next;
arr_insert(myarray, next_item);
printf("%d\n",next_item);
free_arr(myarray);
}
}
ただし、2番目の番号をスキャンしようとすると、次のように表示されます
int arr_length(struct sorted_dyn_array * arr) {
return arr->length;
}
無効なアクセス メモリ。誰か助けてくれませんか?私は午後のように過ごしますが、どこがうまくいかないのかまだわかりません。前もって感謝します。