当前位置: 首页 > news >正文

网站定制设计服务需要使用的技术三好街网站建设与维护

网站定制设计服务需要使用的技术,三好街网站建设与维护,电脑怎样做幻灯片的网站,磁力下载目录 数据的逻辑结构数据的物理结构算法的五大特性好的算法目标时间复杂度与空间复杂度线性表的顺序存储(顺序表) 6.1 静态分配 6.2 动态分配 6.3 基本操作及时间复杂度 一、数据的逻辑结构 数据的逻辑结构描述数据元素之间的逻辑关系,分为…

目录

  1. 数据的逻辑结构
  2. 数据的物理结构
  3. 算法的五大特性
  4. 好的算法目标
  5. 时间复杂度与空间复杂度
  6. 线性表的顺序存储(顺序表)
    6.1 静态分配
    6.2 动态分配
    6.3 基本操作及时间复杂度

一、数据的逻辑结构

数据的逻辑结构描述数据元素之间的逻辑关系,分为以下四类:

1. 集合结构

  • 特点:元素仅属于同一集合,无其他关系。
  • 示例:学生成绩表中的所有学生。

2. 线性结构

  • 特点:元素间存在一对一关系。
    • 除首元素外,每个元素有唯一前驱;
    • 除尾元素外,每个元素有唯一后继。
  • 示例:数组、链表。

3. 树形结构

  • 特点:元素间存在一对多关系。
  • 示例:文件系统目录、组织架构。

4. 图形结构

  • 特点:元素间存在多对多关系。
  • 示例:社交网络、交通网络。

二、数据的物理结构

数据的物理结构描述数据在计算机中的存储方式,分为以下四类:

存储方式特点
顺序存储逻辑相邻的元素物理位置相邻(如数组)。
链式存储逻辑相邻的元素物理位置可不相邻,通过指针关联(如链表)。
索引存储建立索引表,通过关键字快速定位(如数据库索引)。
散列存储根据关键字直接计算存储地址(哈希表)。

三、算法的五大特性

  1. 有穷性:算法必须在有限步骤内终止。
  2. 确定性:相同输入必得相同输出,无歧义。
  3. 可行性:每一步操作可通过基本运算实现。
  4. 输入:0个或多个输入。
  5. 输出:至少1个输出。

四、好的算法目标

  • 正确性 ✅:算法能正确解决问题.
  • 可读性 📖:代码易于理解与维护.
  • 健壮性 🛡️:对非法输入有合理处理机制.
  • 高效性 ⚡:时间与空间复杂度低.

五、时间复杂度与空间复杂度

1. 时间复杂度

  • 计算规则
    • 保留最高阶项,忽略系数(例如,T(n) = 3n + 3 → O(n))。
    • 嵌套循环关注最深层循环次数.
  • 常见复杂度排序
    O(1) < O(log n) < O(n) < O(n log n) < O(n²) < O(2ⁿ) < O(n!)

示例代码

void fun(int n) {int i = 1;             while (i <= n) {       i++;printf("hello");    }printf("linux");        
}
// 时间复杂度 T(n) = 3n + 3 → O(n)

2. 空间复杂度

  • 定义:算法运行所需的辅助空间大小.
  • 原地工作:空间复杂度为 O(1)(例如,变量交换).

六、线性表的顺序存储(顺序表)

顺序表通过数组实现,支持快速随机访问,但增删操作效率较低.

静态分配

#include <stdio.h>
#define MaxSize 10typedef struct {int data[MaxSize];  int length;         
} SqList;// 初始化
void InitList(SqList *L) {for (int i = 0; i < MaxSize; i++) L->data[i] = 0;L->length = 0;
}int main() {SqList L;InitList(&L);return 0;
}

动态分配

#include <stdio.h>
#include <stdlib.h>
#define InitSize 10typedef struct {int *data;       int MaxSize;     int length;      
} SqList;// 初始化
void InitList(SqList *L) {L->data = (int *)malloc(InitSize * sizeof(int));L->MaxSize = InitSize;L->length = 0;
}// 扩容
void IncreaseSize(SqList *L, int len) {L->data = (int *)realloc(L->data, (L->MaxSize + len) * sizeof(int));L->MaxSize += len;
}int main() {SqList L;InitList(&L);IncreaseSize(&L, 5);  return 0;
}

基本操作及时间复杂度

操作时间复杂度说明
按位查找O(1)直接通过下标访问元素.
按值查找O(n)遍历数组查找目标值.
插入O(n)需移动后续元素(平均n/2次).
删除O(n)需移动后续元素.

代码示例(插入与删除)

// 插入元素
bool ListInsert(SqList *L, int i, int e) {if (i < 0 || i > L->length || L->length >= L->MaxSize) return false;for (int j = L->length; j > i; j--) L->data[j] = L->data[j - 1];L->data[i] = e;L->length++;return true;
}// 删除元素
bool ListDelete(SqList *L, int i, int *e) {if (i < 0 || i >= L->length) return false;*e = L->data[i];for (int j = i; j < L->length - 1; j++) L->data[j] = L->data[j + 1];L->length--;return true;
}

http://www.dtcms.com/a/611554.html

相关文章:

  • 哪些指纹浏览器支持模拟SSL指纹
  • 宜春做网站哪里好惠州网站建设领头
  • 【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
  • BuildingAI 控制台智能体菜单和页面技术架构
  • 保定网站制作系统陕西省网站开发
  • 如何在跨部门沟通失误后进行协调与澄清
  • VS2010 C语言编译器使用教程 | 如何高效配置和优化C语言编译环境
  • 常州网站建设要多少钱濮阳免费网站建设
  • 学了lamp做网站就足够了吗无忧中英繁企业网站系统 完整
  • ubuntu:beyond compare 4 This license key has been revoked 解决办法
  • 基于OSip协议栈的GB28181视频平台--jrtp传输过程中作为接收方不发送rtcp包问题处理
  • java加密启动报错
  • SpringAOP、连接点、通知类型、通知顺序、切入点表达式
  • 平面设计师参考网站开发公司总经理竞聘报告
  • 手机可以看的网站如何查看网站是什么语言做的
  • 电源完整性11-电容安装电感的影响因素
  • 手机如何做车载mp3下载网站互联网公司排名深信服
  • 电商网站建设定制北京网站定制价格表
  • 水利网站建设管理汇报广告网站制作多少钱
  • 新建茶叶网站文章内容建设电子商务网站建设工资
  • SAP 如何恢复电子表格EXCEL导出允许选择格式
  • 瓦房店 网站建设二级域名怎么解析
  • 国外做化学申报的网站文化类网站是不是休闲娱乐类网站
  • 最新版LangChain 1.0快速入门介绍
  • 广州开发网站服务设计一个电商网站的首页
  • 单页网站开发网站开发初学
  • 怎样建公司网站有什么网站可以做宣传图片
  • 易缴缴:开启注册资金实缴无忧新时代
  • Java基础——数组1
  • 关于做公司网站成都企业管理培训课程