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

【数据结构】七大排序

文章目录

    • 💐1. 插入排序
      • 🌼1.1 直接插入排序
      • 🌼1.2 希尔排序
    • 💐2. 选择排序
      • 🌼2.1 直接选择排序
      • 🌼2.2 堆排序
    • 💐3. 交换排序
      • 🌼3.1 冒泡排序
      • 🌼3.2 快速排序
        • 🌼3.2.1 快速排序优化
        • 🌼3.2.2 快速排序非递归
    • 💐4. 归并排序
      • 🌼4.1 基本思想
    • 💐6. 海量数据进行排序

**内部排序:**数据全部放在内存中的排序

**外部排序:**如果数据量比较大,内存中放不下,不能在内外存之间进行数据的移动,需要放在硬盘上进行排序,这样的排序称为外部排序;

学习排序要熟练的掌握每一种排序的时间复杂度,稳定性,这样在场景中才可以运用自如;

💐1. 插入排序

🌼1.1 直接插入排序

遍历集合中的每一个元素,每一个元素都作为一个关键码与前面的元素作比较,如果小于前面的元素,前面的元素就向后移动,直到遇见比关键码大的元素,就插入在该元素后一个位置,这也会使得每一个数值作为关键码时,前面的元素都是已经排好序的;
在这里插入图片描述
在这里插入图片描述

直接插入排序特性:

  1. 元素集合越接近有序,直接插入排序时间效率就越高(因为,如果前面都是13456已经排序好的,忽然遇见一个2,那么前面需要移动的元素就会更多)

  2. 时间复杂度:

    最好的情况是O(n),数组本来就是有序的 例如 1 2 3 4 5

    最坏情况是O(n^2),数组是逆序的 例如 5 4 3 2 1

  3. 空间复杂度:O(1)

  4. 稳定性:稳定

    这里提到了稳定性,下面来解释一下什么是稳定性:

    稳定性:假设在一个序列中,出现了相同的数据,经过排序之后,这些相同的数据之间的相对位置保持不变,比如,r[i] = r[j], 在排序之前,r[i] 在 r[j] 之前,排序之后,r[i] 仍然在 r[j] 之前,则这样的排序称为是稳定的,反之是不稳定的;而且一个稳定的排序是可以变成不稳定的,但是一个不稳定的排序是不可以变成稳定的;

    在这里插入图片描述

代码实现

//直接插入排序public void insert(int[] array) {//元素数量不能小于1if(array.length < 1) {return;}//定义i遍历每一个元素for(int i = 1; i<array.length; i++) {//定义j遍历i前面的元素int j = i-1;//定义关键码key保存i对应的值int key = array[i];for(; j>=0; j--) {//符合条件进行移动if(array[j] > key) {//如果这里变成>=就变成了不稳定的array[j+1] = array[j];}else {break;}}//最后将key插入array[j+1] = key;}}

🌼1.2 希尔排序

思想:希尔排序又称缩小增量法, 定义一个增量值,将集合中的数据按照这个增量值进行分组,每一组中元素之间的距离都是这个增量值,每一次缩小增量时都进行了预排序,最后增量值为1时,完成排序;
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

希尔排序特性:

  1. 希尔排序是对直接插入排序的优化

  2. 当gap > 1 时都是预排序,目的是为了让数组跟趋近有序,当gap == 1时,数组已经接近有序了,这样整体而言就可以达到优化效果;

  3. 希尔排序的时间复杂多每办法确定,因为gap的取值方法很多,导致很难去计算,一般都会对gap进行除2来缩小增量

  4. 稳定性:不稳定

    代码实现:

        //希尔排序public void shellSort(int[] array) {//定义增量int gap = array.length / 2;while(gap > 0) {for(int i = gap; i<array.length; i++) {int j = i - gap;int key = array[i];for(; j>=0; j -= gap) {if(array[j] > key) {array[j+gap] = array[j];}else{break;}}array[j+gap] = key;}gap /= 2;}}
    

💐2. 选择排序

🌼2.1 直接选择排序

思想:每一次从待排序的数据集合中取出最小的一个,然后与序列起始位置处的元素进行交换,直到全部待排序的元素排完;

在这里插入图片描述

代码实现:

//选择排序public void selectSort(int[] array) {if(array.length < 1){return;}for(int i = 0; i<array.length; i++) {//用来存放最小元素下标int min = array[i];//遍历待排序元素for(int j = i; j < array.length; j++) {//符合条件更新最小值if(array[j] < array[min]) {min = j;}}//交换swap(array, i, min);}}private void swap(int[] array, int i, int j) {int tmp = array[i];array[i] = array[j];array[j] = tmp;}

🌼2.2 堆排序

堆排序,根据名字就可以了解到肯定是需要建堆的,而前面也已经讲过了建大(小)根堆的步骤,下面就直接利用现成的大根堆进行讲解;

如果要排升序建立大根堆,排降序建立小根堆,步骤如下:

  1. 先建立一个大根堆

  2. 交换第一个和n-i (i=1、2、3、4….)个节点,直到n-i=0时不用再交换

  3. 进行向下调整,重新构建大根堆结构

    在这里插入图片描述

    代码实现:

      public void heapSort(int[] array) {//建立大根堆buildHeap(array);//拿到最后一个节点的下标int len = array.length-1;for(int i = len; i>0; i--) {//交换第一个和最后一个节点值swap(array, 0, i);//向下调整shiftDown(array, 0, i);}}
    //堆排序//建立大根堆public void buildHeap(int[] array) {int len = array.length;for(int parent = (len-2)/2; parent >= 0; parent--) {shiftDown(array, parent, len);}}//向下调整private void shiftDown(int[] array, int parent, int len) {//求处孩子节点下标int child = (2*parent)+1;while(child < len) {//找到最大的那个孩子节点if(child + 1 < len && array[child] < array[child +1]){child++;}//比较父节点与孩子节点if(array[child] > array[parent]) {swap(array, parent, child);//保证子树的大根堆结构不会被破坏parent = child;child = (2*parent)+1;}else {break;}}}
    

    堆排序特性:

    1. 时间复杂度:O(N*logn),因为每一个元素都需要遍历到,每一次与堆顶元素交换后也都需要进行向下调整;
    2. 空间复杂度:O(1)
    3. 稳定性:不稳定

💐3. 交换排序

思想:对序列中的两个值进行比较,根据比较结果来交换这两个值,特点是:升序(降序)较大(较小)的值向尾部移动,值较小(较大)的数据向首部移动;

🌼3.1 冒泡排序

在这里插入图片描述

代码实现:

    //冒泡排序public void bubbleSort(int[] array) {int len = array.length;boolean flag = true;for(int i = 0; i<len; i++) {for(int j = 0; j<len-i-1; j++) {if(array[j] > array[j+1]) {swap(array, j, j+1);//代码优化,定义一个flagflag = false;}}//如果flag是true,说明遍历一趟下来,没有进行交换,则表示序列此时已经有序了,就不用再遍历剩下的元素了if(flag) {return;}}}

冒泡排序特性:

  1. 时间复杂度:O(N^2)
  2. 空间复杂度:O(1)
  3. 稳定性:稳定

🌼3.2 快速排序

思想:从待排序的序列中任取一个元素作为基准值,然后遍历这个序列,让每个元素都与基准值比较,最后这个序列会根据基准分为两个左右子序列,左子序列中所有的值都比基准小,右子序列中所有的值都比基准大,然后再分别对两个子序列进行分割,最后序列就会变成有序

 //快速排序public void quick_sort(int[] array) {//定义左边界和右边界int left = 0;int right = array.length-1;//进行快速排序quickSort(array, left, right);}private void quickSort(int[] array, int left, int right) {//出口为左右边界相等时或右边界小于左边界if(right - left <=1) {return;}//求基准,此时序列会分为左右两个子序列//求基准的方法分为三种int div = partion(array);//分割成功后,根据div分为左右两部分[left, div] 和 [div+1, right]//递归[left, div]quickSort(array, left, div);//递归[right, div+1]quickSort(array, div+1, right);}

以上就是快速排序的模板,有点类似与二叉树的遍历,重点就是求基准的方法,下面介绍三种求基准的方法;

  1. Hoare法

在这里插入图片描述

代码实现:

    private int hoare(int[] array, int left, int right) {//记录基准值int key = array[left];//记录基准值下标int pos = left;while(left < right){//寻找比基准值小的元素while(left < right && array[right] >= key) {right--;}//寻找比基准值大的元素while(left < right && array[left] <= key) {left++;}//交换swap(array, left, right);}//根据基准分割成两个子序列swap(array, left, pos);return left;}
  1. 挖坑法

    在这里插入图片描述

    代码实现:

    //挖坑法private int digHole(int[] array, int left, int right) {//存储基准值int key = array[left];while(left < right) {//寻找比基准小的元素while(left < right && array[right] >= key) {right--;}//将left坑填上array[left] = array[right];//寻找比基准值大的元素while(left < right && array[left] <= key) {left++;}//将right坑填上array[right] = array[left];}array[left] = key;return left;}
    
  2. 前后指针法
    在这里插入图片描述

    代码实现

        private int twoPointer(int[] array, int left, int right) {int pre = left;int cur = pre+1;while(cur < array.length){if(array[cur]<array[left] && array[++pre] != array[cur]) {swap(array, cur, pre);}cur++;}swap(array, left, pre);return pre;}
    

注意点:

如果利用快速排序的方法对十万个有序的数据进行排序,就造成了栈溢出,因为,如果本来就是升序的话,这颗二叉树就是一颗单支树,而采用快速排序时,是要进行递归的,每一次递归都是需要在栈上开辟空间的,造成了时间复杂度是 O(n^2), 空间复杂度是 O(n), 所以就会遭成栈溢出:
在这里插入图片描述
在这里插入图片描述

🌼3.2.1 快速排序优化

下面介绍对快速排序进行优化,为了防止栈溢出,就要减少递归次数, 如果要减少递归次数就要降低树的高度,步骤为:

在这里插入图片描述

  1. 利用三数取中法找key

在这里插入图片描述

   private void quickSort(int[] array, int left, int right) {//出口为左右边界相等时或右边界小于左边界if(right - left <=1) {return;}//三数取中int mid = midOfThree(array, left, right);//和第一个交换swap(array, left, mid);//求基准,此时序列会分为左右两个子序列//求基准的方法分为三种int div = hoare(array, left, right);//int div = digHole(array, left, right);//int div = twoPointer(array, left, right);//分割成功后,根据div分为左右两部分[left, div] 和 [div+1, right]//递归[left, div]quickSort(array, left, div);//递归[right, div+1]quickSort(array, div+1, right);}private int midOfThree(int[] array, int left, int right) {//找中间值int mid = (right- left)/2+left;//查找第二大数字if(array[left] < array[right]) {//情况1: 5  3  9if(array[mid] < array[left]) {return left;}else if(array[mid] > array[right]) {//情况2:3  9  5return right;}else {return mid;}}else {//情况1:5  9  3if(array[mid] > array[left]) {return left;}else if(array[mid] < array[right]) {//情况2:9  3  5return right;}else {return mid;}}}

在这里插入图片描述

虽然利用三数取中法采用了降低树的高度,但是很可能还会造成栈溢出,但是如果在其他的编译器上可能就能跑过,一个原因是IDEA默认的栈空间比较小,解决方法是可以修改IDEA默认的栈空间大小:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

另一个原因是对于三数取中后代码还可以进行优化:

上述三数取中法是防止出现单支树而导致栈溢出情况,从而通过降低树的高度进行解决,但是例如一下这种情况:
在这里插入图片描述

2.当递归到小区间时可以采用插入排序

当递归到小区间时,序列已经趋于有序了,而插入排序在序列趋于有序的情况下效率最高,所以在递归到小区间时,可以采用插入排序;

在这里插入图片描述

    if(right - left + 1 <= 15) {//采用插入排序insertOfRange(array, left, right);return;}public void insertOfRange(int[] array, int start, int end) {//定义i遍历每一个元素//对区间内的元素进行插入排序for(int i = start+1; i<= end; i++) {//定义j遍历i前面的元素int j = i-1;//定义关键码key保存i对应的值int key = array[i];for(; j>=0; j--) {//符合条件进行移动if(array[j] > key) {array[j+1] = array[j];}else {break;}}//最后将key插入array[j+1] = key;}}

🌼3.2.2 快速排序非递归

在这里插入图片描述

代码:

public void quickSortNor(int[] array, int left, int right) {Stack<Integer> stack = new Stack<>();//寻找一次基准int pivot = digHole(array, left, right);//判断左边区间是否只有一个元素if(pivot-1 > left){//表示左区间不止一个元素stack.push(left);stack.push(pivot-1);}if(pivot+1 < right) {//表示右区间不止一个元素stack.push(pivot+1);stack.push(right);}//弹出栈中元素while(!stack.isEmpty()) {//弹出左边界和右边界right = stack.pop();left = stack.pop();//再次找基准pivot = digHole(array, left, right);//判断左边区间是否只有一个元素if(pivot-1 > left){//表示左区间不止一个元素stack.push(left);stack.push(pivot-1);}if(pivot+1 < right) {//表示右区间不止一个元素stack.push(pivot+1);stack.push(right);}}}

在这里插入图片描述

快速排序特性:

  1. 时间复杂度:O(n*logn),因为快排对每一个元素都要操作,因为每一个元素都需要logn的时间复杂度,所以n个元素就是n *logn
  2. 空间复杂度:O(logn)
  3. 稳定性:不稳定

💐4. 归并排序

🌼4.1 基本思想

归并排序它是运用了分支算法的思想:分而治之,将一个序列分割成两份,对每一份再进行分割,一直分割到不能再分割,再进行合并;请看图解:

在这里插入图片描述

代码示例:

 //归并排序public void mergeSort(int[] array, int left, int right) {//递归出口if(left >= right) {return;}//求中间位置元素int mid = (right - left) / 2 + left;//递归左序列mergeSort(array, left, mid);//递归右序列mergeSort(array, mid+1, right);//合并两个序列,使序列有序merge(array, left, right, mid);}private void merge(int[] array, int left, int right, int mid){//申请一个数组用来存放合并后的元素int[] tmp = new int[right-left+1];//定义两个序列的首位置int start1 = left;int start2 = mid+1;//记录新数组中待存放元素的下标int index = 0;//合并序列中的元素while(start1 <= mid && start2 <= right){if(array[start1] < array[start2]) {tmp[index++] = array[start1++];}else {tmp[index++] = array[start2++];}}//检查哪一个序列没有遍历完while(start1 <= mid) {tmp[index++] = array[start1++];}while(start2 <= right) {tmp[index++] = array[start2++];}//将tmp的元素再移动到array中for(int i = 0; i<tmp.length; i++) {//i+left 定位到当前的序列的首位置,因为序列被分割后,每一个子序列的首位置都不一样array[i+left] = tmp[i];}}

在这里插入图片描述

归并排序特性:

  1. 时间复杂度:O(n* logn)
  2. 空间复杂度:O(n),因为需要常见新数组
  3. 稳定性:稳定

💐6. 海量数据进行排序

问题:如果有1G的内存,但是要对100G的的数据进行排序,应该怎么办?

解答:

因为100G的数据在内存中放不下,所以要利用外部排序,就像归并排序

外部排序:在磁盘等外部存储上进行的排序

1、将100G数据分为200份小文件,每个文件都是512M

在这里插入图片描述

2.将每一份文件都放进内存中进行排序

在这里插入图片描述

3、进行二路归并,合并200份文件

**在这里插入图片描述**

相关文章:

【数据结构】七大排序

文章目录 &#x1f490;1. 插入排序&#x1f33c;1.1 直接插入排序&#x1f33c;1.2 希尔排序 &#x1f490;2. 选择排序&#x1f33c;2.1 直接选择排序&#x1f33c;2.2 堆排序 &#x1f490;3. 交换排序&#x1f33c;3.1 冒泡排序&#x1f33c;3.2 快速排序&#x1f33c;3.2.…...

区块链实验室(24) - FISCO网络重构

若干次实验以后&#xff0c;FISCO网络中100个节点堆积了不少交易记录&#xff0c;消耗不少磁盘空间&#xff0c;见下图所示&#xff0c;100个节点累计消耗了10G空间。 观察每个节点的磁盘消耗&#xff0c;以node88为例&#xff0c;消耗了107MB&#xff0c;见下图所示。在该节点…...

AI智能写作工具有哪些?永久免费的AI智能写作工具你使用过吗?

AI智能写作是指借助人工智能技术&#xff0c;计算机程序可以自动生成各种文本内容&#xff0c;包括新闻报道、广告文案、科技文章、小说等等。这些AI写作工具通过大数据和深度学习模型&#xff0c;能够分析和模仿人类的写作风格&#xff0c;生成高质量的文本&#xff0c;甚至有…...

23.8.15 杭电暑期多校9部分题解

1002 - Shortest path 题目大意 对于一个数 x x x&#xff0c;可以进行以下三种操作&#xff1a; 1.将 x x x 变成 2 ∗ x 2*x 2∗x 2.将 x x x 变成 3 ∗ x 3*x 3∗x 3.将 x x x 变成 x 1 x1 x1 给定一个数 n n n&#xff0c;问最少操作几次才能将 1 1 1 变成…...

四个BY的区别 HIVE中

在Hive中&#xff0c;有四个BY比较&#xff1a;Order By、Sort By、Distribute By和Cluster By。 Order By是全局排序&#xff0c;只有一个Reducer。它可以按照升序&#xff08;ASC&#xff09;或降序&#xff08;DESC&#xff09;对结果进行排序。Order By子句通常用在SELECT语…...

计时函数与float32 float16 int8 数据转换

个人整理常用 部分来自 ncnn 计时函数 // window 平台 #include <windows.h>double get_current_time() {LARGE_INTEGER freq; // 频率LARGE_INTEGER pc; // 计数QueryPerformanceFrequency(&freq);QueryPerformanceCounter(&pc);return pc.QuadPart * 1000…...

自身免疫疾病诊断原料——博迈伦

自身免疫疾病是一类由免疫系统攻击正常组织和器官而引起的疾病。为了准确地诊断和监测自身免疫疾病&#xff0c;需要使用特定的诊断原料来进行实验室检测。这些诊断原料主要包括抗体试剂、抗原试剂和试剂盒等。 抗体试剂是用于检测和定量分析体内免疫系统产生的抗体的化学试剂。…...

cpu温度监测 Turbo Boost Switcher Pro for mac最新

Turbo Boost Switcher Pro是一款Mac电脑上的应用程序&#xff0c;旨在帮助用户控制和管理CPU的Turbo Boost功能。Turbo Boost是Intel处理器中的一项技术&#xff0c;可以在需要更高性能时自动提高处理器的频率。然而&#xff0c;这可能会导致电池消耗更快和温度升高。 以下是T…...

spring 请求 出现实体类大小写不一致 出现的问题

目录 1.问题背景 2.解决方法 但是会存在返回的既有大写也有小写的问题&#xff0c;需要在get方法也添加对应的注解 3.相关资料 1.问题背景 因数据库某字段存储的为json 格式&#xff0c;且数据库字段要求都有客户指定&#xff0c;因为该功能需要和其他项目进行对接。然后出现…...

zaabix实现对nginx监控

本文使用监控模板net.tcp.listen[port]实现监听端口 实验环境&#xff1a; 首先搭建好zabbix-server &#xff0c;zabbix-agenthttps://mp.csdn.net/mp_blog/creation/editor/132622769?spm1001.2014.3001.9457 而后在zabbix-agent主机上下载一个nginx 登录zabbix网站创建主…...

基于AI视觉的表面缺陷检测设备优势显著,加速制造业数智化转型

作为生产制造过程中不可缺少的一步&#xff0c;表面缺陷检测广泛应用于工业领域&#xff0c;包括3C电子、芯片半导体、食品医药、木材等行业。但随着智能化进程加快&#xff0c;制造工厂生产线的质量检测压力加剧&#xff0c;传统人工表面缺陷检测已经无法满足当前社会较高的检…...

操作系统权限提升(二十六)之数据库提权-MySQL UDF提权

MySQL UDF提权 MySQL介绍 MySQL是最流行的开放源码SQL数据库管理系统&#xff0c;相对于Oracle&#xff0c;DB2等大型数据库系统&#xff0c;MySQL由于其开源性、易用性、稳定性等特点&#xff0c;受到个人使用者、中小型企业甚至一些大型企业的广泛欢迎&#xff0c;MySQL具有…...

基于 IntelliJ 的 IDE 将提供 Wayland 支持

导读对于使用 IntelliJ 开发环境的用户&#xff0c;JetBrains 一直致力于提供原生 Wayland 支持。 JetBrains 正在致力于为基于 IntelliJ 的 IDE 提供 Wayland 支持&#xff0c;以增强 Linux 桌面体验以及在 Windows Subsystem for Linux 下运行。 Wayland 支持功能尚未完成&…...

誉天在线项目~ElementPlus Tag标签用法

效果图 页面展现 <el-form-item label"课程标签"><el-tagv-for"tag in dynamicTags":key"tag"class"mx-1"closable:disable-transitions"false"close"handleClose(tag)"style"margin:5px;">…...

iText实战--Table、cell 和 page event

5.1 使用表和单元格事件装饰表 实现PdfPTableEvent 接口 实现PdfPCellEvent 接口 合并表格和单元格事件 5.2 基本构建块的事件 通用块&#xff08;Chunk&#xff09;功能 段落&#xff08;Paragraph&#xff09;事件 章节&#xff08;Chapter&#xff09;和 区域&#xff08;…...

WampServer下载安装+cpolar内网穿透实现公网访问本地服务【内网穿透】

文章目录 前言1.WampServer下载安装2.WampServer启动3.安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4.固定公网地址访问 前言 Wamp 是一个 Windows系统下的 Apache PHP Mysql 集成安装环境&#xff0c;是一组常用来…...

Elasticsearch 入门 索引、分词器

term, match_phrase, match查询 参考 ElasticSearch match, match_phrase, term的区别 term是对输入不分词&#xff0c;进行全文索引查询。存储时是否启用分词器&#xff0c;会影响查询效果match_phase对输入分词&#xff0c;但要求查询时将每个term都搜到&#xff0c;且顺序…...

Android NDK 中有导出 sp智能指针吗?如果没有,可以用什么方法代替 android::sp 智能指针

Android NDK 中有导出 sp智能指针吗&#xff1f;如果没有&#xff0c;可以用什么方法代替 android::sp 智能指针 Author: Lycan Note: 以下问题解答通过大模型生成&#xff0c;主要用于个人学习和备忘&#xff0c;仅供参考&#xff0c;若有错误或者侵权&#xff0c;请联系我修…...

网络爬虫-----爬虫的分类及原理

目录 爬虫的分类 1.通用网络爬虫&#xff1a;搜索引擎的爬虫 2.聚焦网络爬虫&#xff1a;针对特定网页的爬虫 3.增量式网络爬虫 4.深层网络爬虫 通用爬虫与聚焦爬虫的原理 通用爬虫&#xff1a; 聚焦爬虫&#xff1a; 爬虫的分类 网络爬虫按照系统结构和实现技术&#…...

uniapp级联菜单地点区域使用label值,web端el-cascader绑定的value

效果图 一、uniapp uniapp级联菜单地点区域使用label值 1.ui使用 <uni-forms-item label="地址" name="userArea" required><view class="" style="height: 100%;display: flex;align-items: center;">...

合肥先进光源国家重大科技基础设施项目及配套工程启动会纪念

合肥先进光源国家重大科技基础设施项目及配套工程启动会纪念 卡西莫多 合肥长丰岗集里 肥鸭从此别泥塘 先平场地设围栏 进而工地筑基忙 光阴似箭指日争 源流汇智山水长 国器西北扩新地 家校又添新区园 重器托举有群力 大步穿梭两地间 科教兴邦大国策 技术盈身坦荡行…...

力扣第47天--- 第647题、第516题

# 力扣第47天— 第647题、第516题 文章目录 一、第647题--回文子串二、第516题--最长回文子序列 一、第647题–回文子串 ​ 逻辑梳理清楚了&#xff0c;就还行。没有想象中那么难。注意遍历顺序&#xff0c;i从大到小。 class Solution { public:int countSubstrings(string …...

dll文件找不到,微软官方地址

dll文件找不到&#xff0c;微软官方地址 文件地址dllMicrosoft Visual C 2008 Redistributable Package ATL 安全更新https://www.microsoft.com/zh-cn/download/details.aspx?id10430Visual C Redistributable for Visual Studio 2012 Update 4https://www.microsoft.com/zh…...

【音视频】FLV封装格式

基本概念 文件头(Header)文件体(Body) flv文件头 主要是看signture和typeflags flv文件体 重点&#xff1a;Tag包数据 Tag结构详细说明 注意&#xff1a; 每个Tag的头字段DataSize只是该Tag下data部分的大小&#xff0c;不包括Tag的header部分的大小 音频 AudioTag Data 所在…...

别再纠结线程池池大小、线程数量了,哪有什么固定公式 | 京东云技术团队

可能很多人都看到过一个线程数设置的理论&#xff1a; CPU 密集型的程序 - 核心数 1 I/O 密集型的程序 - 核心数 * 2 不会吧&#xff0c;不会吧&#xff0c;真的有人按照这个理论规划线程数&#xff1f; 线程数和CPU利用率的小测试 抛开一些操作系统&#xff0c;计算机原…...

Redis 数据一致性方案的分析与研究

点击下方关注我&#xff0c;然后右上角点击...“设为星标”&#xff0c;就能第一时间收到更新推送啦~~~ 一般的业务场景都是读多写少的&#xff0c;当客户端的请求太多&#xff0c;对数据库的压力越来越大&#xff0c;引入缓存来降低数据库的压力是必然选择&#xff0c;目前业内…...

【网络安全】黑客自学笔记

1️⃣前言 &#x1f680;作为一个合格的网络安全工程师&#xff0c;应该做到攻守兼备&#xff0c;毕竟知己知彼&#xff0c;才能百战百胜。 计算机各领域的知识水平决定你渗透水平的上限&#x1f680; 【1】比如&#xff1a;你编程水平高&#xff0c;那你在代码审计的时候就会比…...

深入解析Perlin Simplex噪声函数:在C++中构建现代、高效、免费的3D图形背景

引言 在计算机图形中&#xff0c;噪声是一个经常被讨论的话题。无论是为了制造自然的纹理&#xff0c;还是为了模拟复杂的现实世界现象&#xff0c;噪声函数都在其中起着关键作用。而在众多噪声函数中&#xff0c;Perlin Simplex 噪声无疑是最受欢迎的一种。其原因不仅在于其干…...

【计算机辅助蛋白质结构分析、分子对接、片段药物设计技术与应用】

第一天 上午 生物分子互作基础 1.生物分子相互作用研究方法 1.1蛋白-小分子、蛋白-蛋白相互作用原理 1.2 分子对接研究生物分子相互作用 1.3 蛋白蛋白对接研究分子相互作用 蛋白数据库 1. PDB 数据库介绍 1.1 PDB蛋白数据库功能 1.2 PDB蛋白数据可获取资源 1.3 PDB蛋白数据库对…...

免费开箱即用微鳄售后工单管理系统

编者按&#xff1a;本文介绍基于天翎MyApps低代码平台开发的微鳄售后工单管理系统&#xff0c; 引入低代码平台可以帮助企业快速搭建和部署售后工单管理系统&#xff0c; 以工作流作为支撑&#xff0c;在线完成各环节数据审批&#xff0c;解决售后 工单 服务的全生命周期过程管…...

企业网站免费模板/网站开发北京公司

2019独角兽企业重金招聘Python工程师标准>>> JavaScript的self和this使用小结 var self this? Getting Out of Binding Situations in JavaScript Window 对象 js对象中使用_selfthis的原因&#xff1f; 转载于:https://my.oschina.net/letiantian/blog/282715...

b2b官网seo/seo接单

1&#xff0e; Windows SEH 与 C Exception 1) Windows SEH 结构化异常 结构化异常是Windows 操作系统提供的与语言无关的异常处理机制&#xff0c; SHE使用Win32API中的RaiseException()函数来抛出异常&#xff0c;在VC中使用关键字__try和关键字__except来…...

商城网站建站方案/石家庄新闻网头条新闻

一、调试前提 1. Hardware 720p的DSI接口屏hx8394d,MIPI接口相关原理图如下图 通过原理图获取的信息: 1)2.8V VDD供电脚 —— LDO17; 2)1.8V VDD供电脚 —— LDO6; 3)RESET脚 —— GPIO25; 4)TE脚(一般DSI CMD模式下才会使用)—— GPIO24; 5)背光使能脚 —— G…...

平面设计做名片都去那个网站/百度seo报价

左婉琳 胡志刚摘要&#xff1a;为了设计出更加满足用户需求的办公设备&#xff0c;减轻办公综合症对人们的危害。本文以不同特征的人群为调研对象&#xff0c;通过问卷调查以及SPSS软件&#xff0c;分析了现阶段办公桌的用户体验及期望。得知人们对办公桌自身的属性和功能性方面…...

可以做围棋题的网站/搜索引擎付费推广

title: 【D3.js】1.16-更改 SVG 元素的颜色 date: 2022-12-02 14:24 tags: [JavaScript,CSS,HTML,D3.js,SVG] 至此&#xff0c;一个较为完整的rect图已经完成了&#xff0c;但是所有的rect都是黑色。 一、学习目标 如何着色 .attr(“fill”,“navy”); 二、题目 添加 attr() 方…...

网站建设一般涉及后台功能/百度竞价投放

LeetCode 1005&#xff1a;K 次取反后最大化的数组和 &#xff08;简单&#xff09; 题目 描述 给定一个整数数组 A&#xff0c;我们只能用以下方法修改该数组&#xff1a;我们选择某个索引 i 并将 A[i] 替换为 -A[i]&#xff0c;然后总共重复这个过程 K 次。&#xff08;我们…...