Mi informacion de contacto
Correo[email protected]
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Una tabla de secuencia es un tipo de tabla lineal, una estructura de datos que se utiliza para almacenar una secuencia limitada de n elementos de datos con las mismas características.
La estructura lógica de la forma de almacenamiento de la tabla de secuencia es continua y la estructura física también es continua. La capa inferior es una matriz para completar el almacenamiento de datos.
El espacio de la tabla de secuencia estática es fijo, el tamaño de la matriz es fijo y la cantidad de datos almacenados es limitada. Por lo tanto, si el espacio se establece para datos estáticos, será mayor y si es menor. No será suficiente, pero si es más grande, desperdiciará espacio.
La tabla de secuencia dinámica ajusta el tamaño del espacio de acuerdo con las necesidades de espacio de la memoria, lo que reduce en gran medida el desperdicio de espacio. Por lo tanto, la tabla de secuencia se implementa en forma de secuencia de secuencia dinámica.
La implementación de una tabla de secuencia dinámica creará tres archivos para completar:
- 1. Archivo de encabezado de secuencia_list.h, declaración y definición de función
- 2. El archivo fuente de secuencia_list.c implementa la función de la función.
- 3. El archivo fuente de test.c se utiliza para probar la función de la tabla de secuencia.
Una vez creado, implementarlo paso a paso.
1. En el archivo secuencia_list.h, primero debe crear un tipo de estructura personalizada para usar en la lista de secuencias.
#pragma once
//sequence_list.h文件中
#include<stdio.h>
//顺序表存放数据的类型
typedef int SLDATETYPE;
//顺序表的类型创建
typedef struct SequenceList
{
//存放指定类型数据的指针
SLDATETYPE* a;
//存放数据的有效个数
int count;
//属性表空间大小
int size;
}SL;//重命名一个简单的名字
2. Cree una tabla de secuencia en el archivo test.c, luego verifique qué funciones se necesitan y luego implemente las funciones correspondientes a cada función.
//在test.c文件中
//1、首先包含头文件
#include"sequence_list.h"
//3、测试函数test1的任务
void test1()
{
//4、创建一个顺序表
SL s;
//5、顺序表没有初始化需要初始化
SLInitialize(&s);//传址调用
//6、最后不使用时要完成销毁
SLDestroy(&s);
}
//2、创建主函数
int main()
{
//调用测试函数
test1();
return 0;
}
3. Complete la declaración de función correspondiente y la implementación de los archivos de encabezado de squence_list.h y squence_list.c de acuerdo con los requisitos.
- (1) Inicialización de la tabla de secuencia
- (2) Destrucción de la tabla de secuencias
#pragma once
//sequence_list.h文件中
//包含检查头文件
#include<assert.h>
//动态内存开辟函数对应的头文件
#include<stdlib.h>
//顺序表的初始化
void SLInitialize(SL* ps);
//顺序表的销毁
void SLDestroy(SL* ps);
//在squence_list.c文件中
//包含头文件
#include"sequence_list.h"
//顺序表的初始化
void SLInitialize(SL* ps)
{
//对顺序表检查
//要添加对应的<assert.h>头文件
//在sequence_list.h头文件包含就可以了
assert(ps != NULL);
ps->a = NULL;
ps->count = ps->size = 0;
}
//顺序表的销毁
void SLDestroy(SL* ps)
{
assert(ps != NULL);
//动态内存开辟的空间要free
//动态内存开辟函数要添加头文件<stdlib.h>
free(ps->a);
ps->a = NULL;
ps->count = ps->size = 0;
}
4. Continúe probando el archivo test.c.
La función requerida es una función que agrega datos.
Hay tres formas de agregar datos:
- (1)Agregar al final
- (2) Adición de encabezado
- (3)Agregar en cualquier lugar
Necesidad de observar datos, utilizar la función de impresión para lograrlo.
//在test.c文件中
//1、首先包含头文件
#include"sequence_list.h"
//3、测试函数test1的任务
void test1()
{
//4、创建一个顺序表
SL s;
//5、顺序表没有初始化需要初始化
SLInitialize(&s);//传址调用
//添加数据
//7、尾部添加数据
SLPutEnd(&s, 1);
SLPutEnd(&s, 2);
SLPutEnd(&s, 3);
//8、打印数据
SLPrint(&s);
//9、头部插入
SLPutFirst(&s, 5);
SLPutFirst(&s, 4);
SLPrint(&s);
//10、任意位置前插入数据
SLInsert(&s, 0, 3);
SLInsert(&s, s.count-1, 6);
SLInsert(&s, 1, 6);
SLPrint(&s);
//6、最后不使用时要完成销毁
SLDestroy(&s);
}
//2、创建主函数
int main()
{
//调用测试函数
test1();
return 0;
}
//sequence_list.h文件中
//判断空间是否足够
void SLEnough(SL* ps)
{
//空间满了申请空间
if (ps->count == ps->size)
{
int n;
n = (ps->size == 0 ? 4 : ps->size * 2);
SLDATETYPE* tmp = (SLDATETYPE*)realloc(ps->a,n * sizeof(SLDATETYPE));
if (tmp == NULL)
{
//开辟失败退出
exit(1);
}
ps->a = tmp;
tmp = NULL;
ps->size = n;
}
}
//顺序表末尾放置数据
void SLPutEnd(SL* ps, SLDATETYPE x)
{
assert(ps != NULL);
//判断空间是否足够容纳数据
SLEnough(ps);
ps->a[ps->count++] = x;
}
//打印顺序表中的数据
void SLPrint(SL* ps)
{
assert(ps != NULL);
int i = 0;
for (i = 0; i < ps->count; i++)
{
printf("%d", ps->a[i]);
}
printf("n");
}
//顺序表头部插入数据
void SLPutFirst(SL* ps, SLDATETYPE x)
{
assert(ps != NULL);
SLEnough(ps);
for (int i = ps->count; i > 0; i--)
{
ps->a[i] = ps->a[i - 1];
}
ps->a[0] = x;
ps->count++;
}
//顺序表任意位置前插入数据
void SLInsert(SL* ps, int pos, SLDATETYPE x)
{
assert(ps != NULL);
assert(pos >= 0 && pos <= ps->count);
SLEnough(ps);
for (int i = ps->count; i > pos; i--)
{
ps->a[i] = ps->a[i - 1];
}
ps->a[pos] = x;
ps->count++;
}
(1) Eliminación de cola
(2) eliminación del encabezado
(3) Eliminar en cualquier ubicación
(4) Encuentre el subíndice de datos correspondiente
//在test.c文件中
//1、首先包含头文件
#include"sequence_list.h"
//3、测试函数test1的任务
void test1()
{
//4、创建一个顺序表
SL s;
//5、顺序表没有初始化需要初始化
SLInitialize(&s);//传址调用
//添加数据
//7、尾部添加数据
SLPutEnd(&s, 1);
SLPutEnd(&s, 2);
SLPutEnd(&s, 3);
//8、打印数据
//SLPrint(&s);
//9、头部插入
SLPutFirst(&s, 4);
//SLPrint(&s);
//10、任意位置前插入数据
SLInsert(&s, 0, 5);
SLInsert(&s, 0, 6);
SLPrint(&s);
//11、尾部删除数据
SLDeleteEnd(&s);
//l2、头部删除数据
SLDeleteFirst(&s);
//13、任意位置删除数据
SLDelete(&s, 0);
SLPrint(&s);
//14、查找数据对应下标
int ret=SLFind(&s, 6);
if (ret >= 0)
{
printf("找到了,下标为%dn",ret);
}
else
printf("没有找到");
//6、最后不使用时要完成销毁
SLDestroy(&s);
}
//2、创建主函数
int main()
{
//调用测试函数
test1();
return 0;
}
#pragma once
//sequence_list.h文件中
#include<stdio.h>
//包含检查头文件
#include<assert.h>
//动态内存开辟函数对应的头文件
#include<stdlib.h>
//顺序表存放数据的类型
typedef int SLDATETYPE;
//顺序表的类型创建
typedef struct SequenceList
{
//存放指定类型数据的指针
SLDATETYPE* a;
//存放数据的有效个数
int count;
//属性表空间大小
int size;
}SL;//重命名一个简单的名字
//顺序表的初始化
void SLInitialize(SL* ps);
//顺序表的销毁
void SLDestroy(SL* ps);
//判断空间是否足够
void SLEnough(SL* ps);
//顺序表末尾放置数据
void SLPutEnd(SL* ps, SLDATETYPE x);
//打印顺序表中的数据
void SLPrint(SL* ps);
//顺序表头部插入数据
void SLPutFirst(SL* ps, SLDATETYPE x);
//顺序表任意位置前插入数据
void SLInsert(SL* ps, int pos, SLDATETYPE x);
//顺序表尾删
void SLDeleteEnd(SL* ps);
//顺序表头删
void SLDeleteFirst(SL* ps);
//顺序表任意位置删除数据
void SLDelete(SL* ps, int pos);
//顺序表中寻找对应数据下标
int SLFind(SL* ps, SLDATETYPE x);
#define _CRT_SECURE_NO_WARNINGS 1
//在squence_list.c文件中
//包含头文件
#include"sequence_list.h"
//顺序表的初始化
void SLInitialize(SL* ps)
{
//对顺序表检查
//要添加对应的<assert.h>头文件
//在sequence_list.h头文件包含就可以了
assert(ps != NULL);
ps->a = NULL;
ps->count = ps->size = 0;
}
//顺序表的销毁
void SLDestroy(SL* ps)
{
assert(ps != NULL);
//动态内存开辟的空间要free
//动态内存开辟函数要添加头文件<stdlib.h>
free(ps->a);
ps->a = NULL;
ps->count = ps->size = 0;
}
//判断空间是否足够
void SLEnough(SL* ps)
{
//空间满了申请空间
if (ps->count == ps->size)
{
int n;
n = (ps->size == 0 ? 4 : ps->size * 2);
SLDATETYPE* tmp = (SLDATETYPE*)realloc(ps->a,n * sizeof(SLDATETYPE));
if (tmp == NULL)
{
//开辟失败退出
exit(1);
}
ps->a = tmp;
tmp = NULL;
ps->size = n;
}
}
//顺序表末尾放置数据
void SLPutEnd(SL* ps, SLDATETYPE x)
{
assert(ps != NULL);
//判断空间是否足够容纳数据
SLEnough(ps);
ps->a[ps->count++] = x;
}
//打印顺序表中的数据
void SLPrint(SL* ps)
{
assert(ps != NULL);
int i = 0;
for (i = 0; i < ps->count; i++)
{
printf("%d", ps->a[i]);
}
printf("n");
}
//顺序表头部插入数据
void SLPutFirst(SL* ps, SLDATETYPE x)
{
assert(ps != NULL);
SLEnough(ps);
for (int i = ps->count; i > 0; i--)
{
ps->a[i] = ps->a[i - 1];
}
ps->a[0] = x;
ps->count++;
}
//顺序表任意位置前插入数据
void SLInsert(SL* ps, int pos, SLDATETYPE x)
{
assert(ps != NULL);
assert(pos >= 0 && pos <= ps->count);
SLEnough(ps);
for (int i = ps->count; i > pos; i--)
{
ps->a[i] = ps->a[i - 1];
}
ps->a[pos] = x;
ps->count++;
}
//顺序表尾删
void SLDeleteEnd(SL* ps)
{
assert(ps != NULL);
if (ps->count == 0)
{
printf("数据已经删完了n");
}
else
{
ps->count--;
printf("删除成功n");
}
}
//顺序表头删
void SLDeleteFirst(SL* ps)
{
assert(ps != NULL);
if (ps->count == 0)
{
printf("数据已经删完了n");
}
else
{
for (int i = 0; i < ps->count - 1; i++)
{
ps->a[i] = ps->a[i + 1];
}
ps->count--;
printf("删除成功n");
}
}
//顺序表任意位置删除数据
void SLDelete(SL* ps, int pos)
{
assert(ps != NULL);
assert(pos >= 0 && pos <= ps->count);
if (ps->count == 0)
{
printf("数据已经删完了n");
}
else
{
for (int i = pos; i < ps->count - 1; i++)
{
ps->a[i] = ps->a[i + 1];
}
ps->count--;
printf("删除成功n");
}
}
//顺序表中寻找对应数据下标
int SLFind(SL* ps, SLDATETYPE x)
{
assert(ps != NULL&&ps->a != NULL);
for (int i = 0; i < ps->count; i++)
{
if (ps->a[i] == x)
{
return 1;
}
}
return -1;
}