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

C/C++基础知识复习(53)

1. ​插入排序 & 计数排序

插入排序:
void insertionSort(int arr[], int n) {
    for (int i = 1; i < n; i++) {
        int key = arr[i];
        int j = i-1;
        while (j >= 0 && arr[j] > key) {
            arr[j+1] = arr[j];
            j--;
        }
        arr[j+1] = key;
    }
}
  • 时间复杂度:O(n²)
  • 空间复杂度:O(1)
  • 稳定性:稳定
计数排序:
void countingSort(int arr[], int n) {
    int maxVal = *std::max_element(arr, arr+n);
    std::vector<int> count(maxVal+1, 0);
    for (int i = 0; i < n; i++) count[arr[i]]++;
    int idx = 0;
    for (int i = 0; i <= maxVal; i++) {
        while (count[i]--) arr[idx++] = i;
    }
}
  • 时间复杂度:O(n+k)
  • 空间复杂度:O(k)
  • 稳定性:稳定

2. ​数据库的三范式

数据库的三范式是关系数据库设计的规范化原则,包括:

  1. 第一范式(1NF)​:每个字段都是原子的,不可再分。
  2. 第二范式(2NF)​:在1NF基础上,非主键字段完全依赖于主键。
  3. 第三范式(3NF)​:在2NF基础上,消除传递依赖。
通俗解释:

三范式就像整理房间的规则,确保数据存储的合理性和高效性。

第一范式(1NF)​:每个物品都放在固定的位置,不能乱放。

第二范式(2NF)​:每个物品都放在它专属的抽屉里。

第三范式(3NF)​:抽屉里不能放其他抽屉的钥匙。


http://www.kler.cn/a/576900.html

相关文章:

  • ChatGPT4.5详细介绍和API调用详细教程
  • 【原创】springboot+vue城市公交网系统设计与实现
  • 无约束优化问题的求解
  • 【大模型技术】LlamaFactory 的原理解析与应用
  • 二、IDE集成AI助手豆包MarsCode保姆级教学(使用篇)
  • 【GPT入门】第2课 跑通第一openAI程序
  • hadoop框架与核心组件刨析(一)基础架构
  • VSCode知名主题带毒 安装量900万次
  • 【Linux】权限相关知识点
  • UDP学习笔记(一)为什么UDP需要先将数据转换为字节数组
  • Spring Boot 本地缓存指南:提升应用性能的利器
  • 基于Debian的SVN服务器自动安装脚本
  • 广告营销,会被AI重构吗?
  • Ubuntu 22.04 LTS 入门教学文档
  • Wifi连接正常却无法上网怎么回事 原因及解决方法
  • 如何搭建个人静态住宅IP:从零开始
  • k8s中pod 的创建开始到结束详细过程
  • C++vector类
  • c语言程序设计--(结构体、共用体)冲刺考研复试中的面试问答,来看看我是怎么回答的吧!
  • 基于大模型预测的新型隐球菌脑膜炎综合诊疗研究报告