七大排序算法
文章目录
- 排序的概念及引用
- 1.插入排序
- 2.希尔排序(缩小增量排序)
- 3.选择排序
- 4.堆排序
- 5.冒泡排序
- 6.快速排序
- 7.归并排序
- 8.代码排序部分的测试
- 9.代码加效果大致测试时间(仅供参考)
排序的概念及引用
排序:将数据按照特定的规律排成递增或递减的操作
稳定性:例如arr数组中arr[i]==arr[i+1]但在排序后arr[i+1]排在arr[i]前面了则是不稳定的反之稳定
已下方法都是按照递增排序的。
swap方法(交换)代码:
private static void swap(int []arr,int ret1,int ret2){int temp=arr[ret1];arr[ret1]=arr[ret2];arr[ret2]=temp;}
1.插入排序
基本思路将指定的数插入到了原本已经有序的数组中,直到数组全部有序。
在此写了两种方法,变化不大。
public static void paixu1(int arr[]){for(int i=1;i<arr.length;i++){int temp=arr[i];for ( int j=i-1;j>=0;j--){if(arr[j]>temp){//直接插入到arr[j]位置arr[j+1]=arr[j];arr[j]=temp;}else {break;}}}}
public static void paixu2(int arr[]){for(int i=1;i<arr.length;i++){int temp=arr[i];int j=i-1;for (;j>=0;j--){if(arr[j]>temp){arr[j+1]=arr[j];//找到temp的正确位置}else {break;}}arr[j+1]=temp;//找到后再插入}}
插入排序:时间复杂度为O(n~n^2);空间复杂度为O(1);稳定
2.希尔排序(缩小增量排序)
基本思路:将数组分为gap小组进行排序,直到gap为1该数组就完成了排序,使用的底层排序逻辑就是在插入排序的基础下优化。
public static void haset(int arr[]) {int gap = arr.length;while (gap >1) {gap /= 2;hpa(arr,gap);}}private static void hpa(int arr[],int gap){for(int i=1;i<arr.length;i++){int temp=arr[i];int j=i-gap;for (;j>=0;j-=gap){if(arr[j]>temp){arr[j+gap]=arr[j];}else {break;}}arr[j+gap]=temp;}}
希尔排序:时间复杂度为O(n~n^2);空间复杂度为O(1);不稳定
3.选择排序
基本思路:在需要排序的数据中找出最大或最小的值放在特定位置后面按照这样继续遍历数组直至数组遍历完成。
public static void xtion1(int arr[]){for (int i=0;i< arr.length;i++){int temp=i;for (int j=i+1;j< arr.length;j++){if(arr[j]<arr[temp]) {temp= j;}}if(arr[temp]<arr[i]){swap(arr,i,temp);}}}
在此基础上可以进行优化一次性找出最大和最小
public static void xtion2(int arr[]){int left=0;int right=arr.length-1;while(left<right){int minindex= left;int maxindex=left;//用maxindex=right就需要去套两个for循环增加运行时间for(int i=left+1;i<=right;i++){if(arr[i]<arr[minindex]){minindex=i;}if(arr[i]>arr[maxindex]){maxindex=i;}}swap(arr,left,minindex);//注意第一个数是最大值就需要特殊处理防止刚换过的最小又去换去最大值的位置这个逻辑就直接崩了if(left==maxindex){maxindex=minindex;}swap(arr,right,maxindex);left++;right--;}}
选择排序:时间复杂度为O(n^2);空间复杂度为O(1);不稳定
4.堆排序
基本思路:运用堆的性质排序。
我们需要的是递增排序所以使用大堆然后交换0下标与end下标进行end–再进行向下调整。
代码:
public static void duipa(int []arr){int end= arr.length-1;dadui(arr,end);//构建堆的过程可以使用xiato方法代替可以节省大量时间消耗(才符合时间复杂度O(n*logn)),这里就直接展示如何构建堆的过程了while (end>0){swap(arr,0,end);//只需要向下调整end--;xiato(arr,end);}}private static void xiato(int[]arr,int end) {int parten=0;int childer = parten * 2 + 1;while (childer <= end) {if (childer + 1 <= end&& arr[childer] < arr[childer + 1]) {childer++;}if (arr[parten] < arr[childer]) {swap(arr, parten, childer);parten = childer;childer = parten * 2 + 1;} else {break;}}}private static void swap(int[]arr,int ret1,int ret2){int temp=arr[ret2];arr[ret2]=arr[ret1];arr[ret1]=temp;}private static void dadui(int []arr,int end){int usize= end;for (int parten=(usize-1)/2;parten>=0;parten--){int childer=parten*2+1;while(childer<=usize){if(childer+1<=usize&&arr[childer]<arr[childer+1]){childer++;}if(arr[parten]<arr[childer]){swap(arr,parten,childer);parten=childer;childer=parten*2+1;}else{break;}}}}
堆排序:时间复杂度为O(n*logn);空间复杂度为O(1);不稳定
5.冒泡排序
基本思路:基于指定数据与其余数据相比进行交换。
代码:
public static void mppx(int []arr){for (int i = 0; i <arr.length ; i++) {for (int j = 0; j< arr.length-1-i; j++) {//一次次确定最大值if(arr[j]>arr[j+1]){swap(arr,j,j+1);}}}}
在此基础上进行优化,优化的思路为当数组已经排好了就可以直接退出循环减少时间的消耗。
优化代码:```javapublic static void mppx(int []arr){for (int i = 0; i <arr.length ; i++) {boolean flag=false;//作为标记是否有进行交换for (int j = 0; j< arr.length-1-i; j++) {//一次次确定最小值if(arr[j]>arr[j+1]){swap(arr,j,j+1);flag=true;}}if(!flag){//说明没有进入第二层循环却没有进行交换代表已经排好了break;}}}
冒泡排序:时间复杂度为O(n^2);空间复杂度为O(1);稳定
6.快速排序
快速排序是Hoare于1962年提出的⼀种⼆叉树结构的交换排序⽅法,其基本思想为:任取待排序元素序列中的某元素作为基准值,按照该排序码将待排序集合分割成两⼦序列,左⼦序列中所有元素均⼩于基准值,右⼦序列中所有元素均⼤于基准值,然后最左右⼦序列重复该过程,直到所有元素都排列在相应位置上为⽌。
三种不同方法:Hoare版,挖坑法,前后指针法。
cent方法是便于找到了数组的中位数去大大优化代码的时间消耗,当第一次就找到中间值去分割是优解所以创建cent方法去找去中位数。
private static int cent(int []arr,int start,int end){//找中位数的下标int mid=(start+end)/2;if(arr[start]<arr[end]){if(arr[mid]<arr[start]){return start;}if(arr[mid]>arr[end]){return end;}else{return mid;}}else {if(arr[mid]>arr[start]){return start;}if(arr[mid]<arr[end]){return end;}else{return mid;}}}
Hoare:分为递归与非递归
代码1递归:
去注意为什么利用递归和什么时候需要递归的跑代码和递归结束的条件能更好的理解。
public static void quikpai(int[]arr){quik(arr,0, arr.length-1);}
private static void quik(int[]arr,int start,int end){if(start>=end){//注意递归结束的条件return;}swap(arr,start,cent(arr,start,end));int cent=quike(arr,start,end);quik(arr,start,cent-1);quik(arr,cent+1,end);}//作用于找到了指定值的下标而且将其中分为小于和大于指定值的左右两边private static int quike(int []arr,int start,int end){int cent=start;while(start<end){while (start<end&&arr[end]>=arr[cent]){end--;}while (start<end&&arr[start]<=arr[cent]){start++;}swap(arr,start,end);}swap(arr,cent,start);return start;}
代码2非递归:
变动的是quik方法
public static void quikpai1(int[]arr){quik1(arr,0, arr.length-1);}private static void quik1(int[]arr,int start,int end){//不使用递归去快排swap(arr,start,cent(arr,start,end));int cent=quike(arr,start,end);Stack<Integer> stack=new Stack<>();if(cent>start+1){stack.push(start);stack.push(cent-1);}if(cent<end-1){stack.push(cent+1);stack.push(end);}end=stack.pop();start=stack.pop();cent=quike(arr,start,end);while (!stack.isEmpty()){if(cent>start+1){stack.push(start);stack.push(cent-1);}if(cent<end-1){stack.push(cent+1);stack.push(end);}end=stack.pop();start=stack.pop();cent=quike(arr,start,end);}}private static int quike(int []arr,int start,int end){int cent=start;while(start<end){while (start<end&&arr[end]>=arr[cent]){end--;}while (start<end&&arr[start]<=arr[cent]){start++;}swap(arr,start,end);}swap(arr,cent,start);return start;}
挖坑法:
基本思路与Hoare相似,将指定数据下标挖坑;先从end开始向后找到小于指定值的数填入坑中这个坑就是被找到这个值代替了再从start开始向前找到大于指定值的数填入后面的这个新坑中,最后start>=end时再将指定值填入这个坑(数组下标)中。
代码:
public static void wquikpai(int []arr){wquik(arr,0, arr.length-1);}private static void wquik(int[]arr,int start,int end){if(start>=end){return;}int cent=wquike(arr,start,end);wquik(arr,start,cent-1);wquik(arr,cent+1,end);}private static int wquike(int []arr,int start,int end){int cent=start;int paiv=arr[start];while(start<end){while (start<end&&arr[end]>=paiv){end--;}arr[start]=arr[end];while (start<end&&arr[start]<=arr[cent]){start++;}arr[end]=arr[start];}arr[start]=paiv;return start;}
前后指针法
基本思路:int pavi=start ,int cur=start+1 去根据特定条件去使pavi下标停在第一个出现大于arr[start]的下标上而cur停在pavi停好后出现的第一个小于arr[start]的下标上然后两者进行交换,当cur>arr.length()-1结束。
public static void shuang(int []arr){wshuang(arr,0,arr.length-1);}private static void wshuang(int []arr,int start,int end){if(start>end){return;}int ret=wshuange(arr,start,end);wshuang(arr,0,ret-1);wshuang(arr,ret+1,end);}private static int wshuange(int[]arr,int start,int end){int pavi=start;int cur=start+1;while (cur<=end){if(arr[cur]<arr[start]&&arr[++pavi]!=arr[cur]){//这里是关键swap(arr,pavi,cur);}cur++;}//pavi停的位置就是arr[start]的位置;swap(arr,pavi,start);return pavi;}
快速排序的时间复杂度为O(n*logn);空间复杂度为O(logn),不稳定
7.归并排序
基本思路:将数组一直对半分直至数据一个个,在将其两两排序结合,直至整个数组排好。将已有序的⼦序列合并,得到完全有序的序列;即先使每个⼦序列有序,再使⼦序列段间有序。若将两个有序表合并成⼀个有序表,称为⼆路归并
递归方式代码:
public static void merg(int []arr){mergsort(arr,0,arr.length-1);}private static void mergsort(int []arr,int start,int end){if(start==end){return;}int mid=(start+end)/2;mergsort(arr,start,mid);mergsort(arr,mid+1,end);merghebin(arr,start,end,mid);}private static void merghebin(int []arr,int start,int end,int mid){int se=start;int sl=mid;int te=mid+1;int tl=end;int []temparr=new int[end-start+1];int k=0;//表示temparr的下标while (se<=sl&&te<=tl){if(arr[se]<=arr[te]){temparr[k++]=arr[se++];}else {temparr[k++]=arr[te++];}}while (se<=sl){temparr[k++]=arr[se++];}while (te<=tl){temparr[k++]=arr[te++];}for(int i=0;i<end-start+1;i++){arr[i+start]=temparr[i];}}
非递归代码:
public static void merg1(int[]arr){mergsort1(arr,0,arr.length-1);
}
public static void mergsort1(int[]arr,int start,int end){//采用非递归的方式int gap=1;while (gap<arr.length) {for (int i = 0; i < arr.length; i += 2 * gap) {int left = i;int mid = left + gap - 1;int right = mid + gap;if(mid>=arr.length){mid=arr.length-1;}if(right>=arr.length){right=arr.length-1;}merghebin(arr, left,right,mid);}gap *= 2;}
}
private static void merghebin(int []arr,int start,int end,int mid){int se=start;int sl=mid;int te=mid+1;int tl=end;int []temparr=new int[end-start+1];int k=0;//表示temparr的下标while (se<=sl&&te<=tl){if(arr[se]<=arr[te]){temparr[k++]=arr[se++];}else {temparr[k++]=arr[te++];}}while (se<=sl){temparr[k++]=arr[se++];}while (te<=tl){temparr[k++]=arr[te++];}for(int i=0;i<end-start+1;i++){arr[i+start]=temparr[i];}
}
归并排序时间复杂度为O(n*logn);空间复杂度为O(n);稳定。
总结七大排序的时间复杂度,空间复杂度,稳定性
8.代码排序部分的测试
public static void main(String[] args) {int []arr1={5,6,4,2,7,9,1,2};paixu1(arr1);System.out.println("插叙1排序"+Arrays.toString(arr1));int []arr2={64,45,15,51,1,5,31};paixu2(arr2);System.out.println("插叙2排序"+Arrays.toString(arr2));int []arr3={64,112,56,46,95};haset(arr3);System.out.println("希尔排序"+Arrays.toString(arr3));int []arr4={64,45,15,51,1,5,31,88,46,95};xtion1(arr4);System.out.println("选择排序1"+Arrays.toString(arr4));int []arr5={10,6,4,2,7,9,1,2};xtion2(arr5);System.out.println("选择排序2"+Arrays.toString(arr5));int []arr6={8,6,91,3,56,1,656,2};duipa(arr6);System.out.println("堆排序"+Arrays.toString(arr6));int []arr7={2,1,3,7,5};mppx(arr7);System.out.println("冒泡排序"+Arrays.toString(arr7));int []arr8={8,6,4,2,7,9,1,2};quikpai(arr8);System.out.println("Hoare快速排序"+Arrays.toString(arr8));int []arr9={4,5,8,1,2,9,11,15,88};wquikpai(arr9);System.out.println("挖坑法快速排序"+Arrays.toString(arr9));int []arr10={4,5,8,1,2,9,11,88,18};shuang(arr10);System.out.println("前后指针法快排"+Arrays.toString(arr10));int []arr11={4,5,8,1,2,9,11,88,18};quikpai1(arr11);System.out.println("非递归快排"+Arrays.toString(arr11));int []arr12={45,65,45,89,97,111,12,1,2,5,6};merg(arr12);System.out.println("递归法归并排序"+Arrays.toString(arr12));int []arr13={45,65,45,89,97,111,12,1,2,5,6};merg1(arr13);System.out.println("非递归归并排序"+Arrays.toString(arr13));}
9.代码加效果大致测试时间(仅供参考)
数据随机时:
数据逆序时:
import java.util.Arrays;
import java.util.Random;public class time {public static void fuztarr(int []arr){for(int i=0;i<arr.length;i++){//数据逆序arr[i]=arr.length-i;}}public static void wfuzarr(int []arr){Random random=new Random(10000);//数据随机for (int i=0;i<arr.length;i++){arr[i]=random.nextInt();}}public static void chaxu1(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.paixu1(arr);long end1=System.currentTimeMillis();System.out.println("插叙1排序的时间:"+(end1-start1));}public static void chaxu(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.paixu2(arr);long end1=System.currentTimeMillis();System.out.println("插叙排序的时间:"+(end1-start1));}public static void xtion(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.xtion1(arr);long end1=System.currentTimeMillis();System.out.println("选择排序的时间:"+(end1-start1));}public static void qike(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.quikpai(arr);long end1=System.currentTimeMillis();System.out.println("Hoare快速排序的时间:"+(end1-start1));}public static void wqike(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.wquikpai(arr);long end1=System.currentTimeMillis();System.out.println("挖坑法快速排序的时间:"+(end1-start1));}public static void shenqike(int[]arr){arr= Arrays.copyOf(arr,arr.length);long start1=System.currentTimeMillis();test.shuang(arr);long end1=System.currentTimeMillis();System.out.println("前后指针快速排序的时间:"+(end1-start1));}public static void haxu(int []arr){arr= Arrays.copyOf(arr,arr.length);long start2=System.currentTimeMillis();test.haset(arr);long end2=System.currentTimeMillis();System.out.println("希尔排序的时间:"+(end2-start2));}public static void mp(int []arr){arr= Arrays.copyOf(arr,arr.length);long start2=System.currentTimeMillis();test.mppx(arr);long end2=System.currentTimeMillis();System.out.println("冒泡排序的时间:"+(end2-start2));}public static void main(String[] args) {//测试数据要稍微大,不然都是0.多少毫秒都是显示0不能直观的表示int []arr=new int [15000];//fuztarr(arr);wfuzarr(arr);chaxu1(arr);chaxu(arr);haxu(arr);mp(arr);xtion(arr);qike(arr);}
}
相关文章:
七大排序算法
文章目录 排序的概念及引用1.插入排序2.希尔排序(缩小增量排序)3.选择排序4.堆排序5.冒泡排序6.快速排序7.归并排序8.代码排序部分的测试9.代码加效果大致测试时间(仅供参考) 排序的概念及引用 排序:将数据按照特定的规律排成递增或递减的操作 稳定性:…...
代理模式实现
一、概念:代理模式属于结构型设计模式。客户端不能直接访问一个对象,可以通过代理的第三者来间接访问该对象,代理对象控制着对于原对象的访问,并允许在客户端访问对象的前后进行一些扩展和处理;这种设置模式称为代理模…...
国产linux系统(银河麒麟,统信uos)使用 PageOffice 实现后台批量生成PDF文档
PageOffice 国产版 :支持信创系统,支持银河麒麟V10和统信UOS,支持X86(intel、兆芯、海光等)、ARM(飞腾、鲲鹏、麒麟等)、龙芯(LoogArch)芯片架构。 PageOffice 版本&…...
基于若依的脚手架,扩展了flowable、mybatisPlus、lombok、前端美化
前言 若依框架可以说是非常优秀的框架,奈何前端一直有点丑,而且集成的东西比较少,我就基于若依,做了一个轻美化版本,主要集成了工作流、mybatisPlus、lombok等工具。 因为我也在用这个框架为公司做系统,所…...
LeetCode 热题 100 | 矩阵
矩阵基础 使用哈希数组来标记当前行或者列是否出现0按层模拟 73. 矩阵置零 题目讲解:LeetCode 重点: 使用标记数组:用两个标记数组分别记录每一行和每一列是否有零出现。使用两个标记变量:用矩阵的第一行和第一列代替两个标记数组…...
(经过验证)在 Ubuntu 系统中为 VSCode、PyCharm 终端及 Jupyter Notebook 配置代理的完整方案
文章目录 1. 通过系统环境变量配置代理步骤一:打开终端步骤二:编辑 ~/.bashrc 文件步骤三:添加代理环境变量步骤四:保存并关闭文件步骤五:使配置生效步骤六:重启相关应用步骤七:使用代理函数 2.…...
【Linux】sed编辑器二
一、处理多行命令 sed编辑器有3种可用于处理多行文本的特殊命令。 N:加入数据流中的下一行,创建一个多行组进行处理;D:删除多行组中的一行;P:打印多行组中的一行。 1、next命令:N 单行next命…...
STM32 FreeRTOS移植
目录 FreeRTOS源码结构介绍 获取源码 1、 官网下载 2、 Github下载 源码结构介绍 源码整体结构 FreeRTOS文件夹结构 Source文件夹结构如下 portable文件夹结构 RVDS文件夹 MemMang文件夹 FreeRTOS在基于寄存器项目中移植步骤 目录添加源码文件 工程添加源码文件 …...
python 寻找数据拐点
import numpy as np import cv2 from scipy.signal import find_peaks# 示例数据 y_data [365.63258786, 318.34824281, 258.28434505, 228.8913738, 190.87220447, 158.28434505, 129.53035144, 111.95846645, 111.95846645, 120.26517572, 140.71246006, 161.79872204, 180.…...
Windows 蓝牙驱动开发-蓝牙设备栈
蓝牙设备栈 蓝牙驱动程序堆栈包含 Microsoft 为蓝牙协议提供支持的核心部分。 有了这个堆栈,已启用蓝牙的设备可以彼此定位并建立连接。 在此类连接中,设备可以通过各种应用程序交换数据并彼此交互。 下图显示了蓝牙驱动程序堆栈中的模块,以…...
css hover样式调试
调试 hover后才出现的元素如何调试 打开开发者工具,鼠标放在hover时才出现的元素上,然后点击右键不要选中任何选项,将鼠标移动到开发者工具的调试面板中按下N键,此时悬浮的元素不会消失,定位成功 调试元素悬浮样式 …...
【Unity】unity3D 调用LoadSceneAsync 场景切换后比较暗 部门材质丢失
解决方法:两个场景使用同样灯光 现象 直接进入第二个场景是可以正常显示 调用LoadSceneAsync来切换后,第二个场景出现比较暗的情况 解决方法:两个场景使用同样灯光,在loading 的场景中加入灯光。 Light—Directional Light 如果…...
代码随想录二刷|字符串总结
代码随想录二刷|字符串 反转数字 题干 编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间,你必须**原地修改输入数组**、使用 O(1) 的额外空间解决这一问题。 思路 class Soluti…...
Linux浅谈——管道、网络配置和客户端软件的使用
目录 一、管道 1、管道符 2、过滤功能 3、特殊功能 4、扩展处理 5、xargs命令扩展 二、网络配置 1、ifconfig查看网络信息 2、配置文件详解 网卡配置文件位置 3、systemctl查看网卡状态 4、systemctl启动/重启/停止网卡 三、客户端软件 1、什么是SSH 2、常用SSH终…...
HBASE学习(一)
1.HBASE基础架构, 1.1 参考: HBase集群架构与读写优化:理解核心机制与性能提升-CSDN博客 1.2问题: 1.FLUSH对hbase的影响 2. HLog和memstore的区别 hlog中存储的是操作记录,比如写、删除。而memstor中存储的是写入…...
深入解析 Linux 内核中的 IPoIB 驱动:ipoib.h 文件分析
引言 InfiniBand 是一种高性能、低延迟的网络互联技术,广泛应用于高性能计算(HPC)和数据中心。为了在 InfiniBand 网络上运行传统的 IP 协议栈,Linux 内核提供了 IP over InfiniBand (IPoIB) 驱动。ipoib.h 是 IPoIB 驱动的核心头文件,定义了驱动所需的数据结构、常量、宏…...
2025-01-16 思考-人生下半场的归途-那温和的良夜
摘要: 转眼已经不再年轻,生命赠与的礼物,也可以说开始陷入归途。不再被外界推着走之后,发现可以有更多的精力和时间可以用来内视,不被外界种种束缚。 在人生的下半场,其实更多的是接受失去,正如人生上半场…...
【C++篇】红黑树的实现
目录 前言: 一,红黑树的概念 1.1,红黑树的规则 1.2,红黑树的最长路径 1.3,红黑树的效率分析 二,红黑树的实现 2.1,红黑树的结构 2.2,红黑树的插入 2.2.1,大致过程…...
Linux的常用命令(一)
目录 一、文件处理命令 1.文件处理命令ls 2.文件处理命令cd 3.文件处理命令pwd 4.文件处理命令touch 5.文件处理命令mkdir 6.文件处理命令cp 7.文件处理命令mv 8.文件处理命令rm 9.文件处理命令cat 10.文件处理命令more 11.文件处理命令head 12.文件处理命令tail …...
小米vela系统(基于开源nuttx内核)——如何使用信号量进行PV操作
如何使用信号量进行PV操作 前言信号量1. 信号量简介2. NuttX中信号量的创建与使用2.1 Nuttx信号量的初始化和销毁2.2 信号量的等待和发布 3. 信号量的实际应用:下载任务示例3.1 实际代码3.2 代码说明3.3 执行说明 4. 信号量的优势与应用场景5. 常见应用场景…...
(01)STM32—GPIO
1. GPIO简介 GPIO(General Purpose Input Output)通用输入输出端口。可配置为8种输入输出模式。引脚电平:0V~3.3V,部分引脚可容忍5V。输出模式下可控制端口输出高低电平,用以驱动LED、控制蜂鸣器、模拟通信协议输出时…...
浏览器输入http形式网址后自动跳转https解决方法
一、问题描述 使用浏览器 网上冲浪 时会遇到一个情况: 在浏览器中输入“http域名”后会自动变成“https 域名”的形式,此时“https 域名”的网站可能已停止对外提供服务了,这时会出现如下不友好的网页提示: 二、处理方法&#x…...
mybatis的多对一、一对多的用法
目录 1、使用VO聚合对象(可以解决这两种情况) 多对一: 一对多: 2、非聚合的多对一做法: 3、非聚合的一对多做法: 1、使用VO聚合对象(可以解决这两种情况) 当我需要多对一、一对…...
生产管理看板助力节能科技公司实现数据自动化管理
在节能科技公司的生产过程中,数据管理的自动化是提高生产效率和产品质量的关键。然而,许多公司在数据记录、展示、对比和存档方面仍面临诸多痛点,如产品检测数据无法自动记录、缺乏直观的产线状态展示、检测数据对比繁琐耗时,以及…...
网络科技有限公司网络设计
网络科技有限公司网络设计 摘要:伴随着信息科技发展,上网变得一件必不可少的事情,当然网络安全对我们也是越来越重要。像我们的传统网结构是无法为我们的上网提供一个安全的网络环境。锐雯网络科技有限公司就是以网络安全为基本的对网络惊醒…...
C++没有Y Combinator?使用 C++ 实现 Y Combinator(中英双语)
C 中并没有直接内置的 Y Combinator,但通过现代 C 特性(如 lambda 表达式 和 std::function),我们可以实现一个类似 Y Combinator 的功能。 下面我们来详细讲解如何在 C 中实现 Y Combinator。 使用 C 实现 Y Combinator 目标 …...
YOLOv10-1.1部分代码阅读笔记-loaders.py
loaders.py ultralytics\data\loaders.py 目录 loaders.py 1.所需的库和模块 2.class SourceTypes: 3.class LoadStreams: 4.class LoadScreenshots: 5.class LoadImagesAndVideos: 6.class LoadPilAndNumpy: 7.class LoadTensor: 8.def autocast_list(source…...
《戴森球计划》异地远程联机攻略
文章目录 前言1. 下载MOD2.配置cpolar内网穿透3. 主机开启联机3.1 玩家加入游戏 4. 配置固定的TCP端口5. 游玩体验 前言 《戴森球计划》不仅是一款融合了科幻冒险与经营管理元素的游戏,更是一个让玩家在浩瀚宇宙中尽情探索和创造的平台。在这个游戏中,你…...
【Linux跬步积累】—— 线程
🌏博客主页:PH_modest的博客主页 🚩当前专栏:Linux跬步积累 💌其他专栏: 🔴 每日一题 🟡 C跬步积累 🟢 C语言跬步积累 🌈座右铭:广积粮࿰…...
计算机网络 (46)简单网络管理协议SNMP
前言 简单网络管理协议(SNMP,Simple Network Management Protocol)是一种用于在计算机网络中管理网络节点的标准协议。 一、概述 SNMP是基于TCP/IP五层协议中的应用层协议,它使网络管理员能够管理网络效能,发现并解决网…...
模型 前景理论
系列文章 分享模型,了解更多👉 模型_思维模型目录。面对得失,人们更怕失,参考点定输赢。 1 前景理论的应用 1.1 前景理论在投资决策中的应用案例 假设一位投资者面临两个投资方案的选择: 方案A:投资一只…...
Android ScrollView嵌套X5WebView大片空白问题
scrollview嵌套后webview的高度不可控。留有大片空白。 注:官方不建议scrollview嵌套webview 最好让webview自身滚动 解决方案: act_news_detail_wv.setWebViewClient(new WebViewClient() {Overridepublic void onPageFinished(WebView webView, Str…...
频域增强通道注意力机制EFCAM模型详解及代码复现
背景与动机 在深度学习领域,如何有效处理时间序列数据一直是一个重要的研究方向。近年来, 频域分析技术 在时间序列处理中展现出了巨大潜力,特别是离散余弦变换(DCT)因其能够高效捕捉低频信息并避免高频噪声干扰而受到广泛关注。 FECAM模型的开发正是基于这一背景,旨在…...
[计算机网络]一. 计算机网络概论第一部分
作者申明:作者所有文章借助了各个渠道的图片视频以及资料,在此致谢。作者所有文章不用于盈利,只是用于个人学习。 1.0推荐动画 【网络】半小时看懂<计算机网络>_哔哩哔哩_bilibili 1.1计算机网络在信息时代的作用 在当今信息时代&…...
第十三章:数据库技术
文章目录: 一:基础 1.概念 2.特点 3.常见数据库品牌 4.数据库应⽤系统 4.1 C/S 4.2 B/S 5.数据模型的分类 6.名词解析 7.关系运算 二:Access 1.基础 2.操作 2.1 建立表 2.2 维护表 2.3 创建查询 2.4 创建窗体 2.5 创建报表…...
中等难度——python实现电子宠物和截图工具
import io # 文件处理 import nt # windows nt 库直接获取对应的磁盘空间 import time # 时间 import zlib # 加解密 import ctypes # 调用 import struct # 处理字节二进制 import base64 # 编解码 import threading # 线程 import tkinter as tk # tk from datetime…...
构建优雅、高效的 Nodejs 命令行工具 - Archons
目录 项目简介安装基本用法样例创建一个简单的命令行工具使用archons上下文创建进度条 最后 项目地址: https://github.com/noctisynth/archons Bug反馈或功能请求:https://github.com/noctisynth/archons/issues 项目简介 Archons意思是“执政官”,我使…...
源码编译安装httpd 2.4,提供系统服务管理脚本并测试
1.安装httpd wget https://downloads.apache.org/httpd/httpd-2.4.62.tar.gzbmcv tar -zxvf httpd-2.4.62.tar.gz cd httpd-2.4.62 2.安装依赖包 sudo yum install -y gcc make apr-devel apr-util-devel pcre-devel sudo yum groupinstall "Development Tools"…...
【爬虫】某某查cookie逆向
代码仅供技术人员进行学习和研究使用,请勿将其用于非法用途或以任何方式窃取第三方数据。使用该代码产生的所有风险均由用户自行承担,作者不对用户因使用该代码而造成的任何损失或损害承担任何责任。 加密参数 加密参数主要是cookie,其中只有…...
【华为路由/交换机的ssh远程设置】
华为路由/交换机的ssh远程设置 R1(client):10.1.1.1 R2(server):10.1.1.2 R2服务端配置: 生成本机密钥 查看生成的密钥 设置AAA授权验证方式,并设置支持SSH协议 创建本地用户&…...
Linux:System V - 共享内存
1.System V共享内存的原理 通过为用户提供系统调用接口,让用户可以申请一块空间,进程A/B也可以通过系统调用接口将创建好的内存通过页表映射进进程的地址空间。完成让不同的两个进程看见同一份资源的目的。如果未来不想继续通信,取消进程和内…...
闪豆多平台视频批量下载器
1. 视频链接获取与解析 首先,在哔哩哔哩网页中随意点击一个视频,比如你最近迷上了一个UP主的美食制作视频,想要下载下来慢慢学。点击视频后,复制视频页面的链接。复制完成后,不要急着关闭浏览器,因为接下来…...
《鸿蒙Next微内核:解锁人工智能决策树并行计算的加速密码》
在当今人工智能飞速发展的时代,提升运算速度是推动其进步的关键。鸿蒙Next以其独特的微内核特性,为设计决策树的并行计算框架提供了新的思路和契机。 鸿蒙Next微内核特性概述 鸿蒙Next的微内核架构将核心功能模块化,仅保留进程管理、内存管…...
AWS Lambda
AWS Lambda 是 Amazon Web Services(AWS)提供的无服务器计算服务,它让开发者能够运行代码而不需要管理服务器或基础设施。AWS Lambda 会自动处理代码的执行、扩展和计费,开发者只需关注编写和部署代码,而无需担心底层硬…...
Python入门教程丨2.3 流程控制、算法效率分析及优化
流程控制是用于控制程序执行顺序的机制,它决定了程序中的语句按照何种顺序被执行。 本节课将详细讲解 Python 流程控制的三大核心结构:顺序、条件和循环,并配备一些小案例。 1. 顺序结构:从头到尾依次执行 顺序结构是程序中最基…...
NVIDIA发布个人超算利器project digital,标志着ai元年的开启
上图NVIDIA公司创始人兼首席执行官 黄仁勋(Jensen Huang) 这些年被大家熟知的赛博朋克风格一直都是未来的代言词,可以承载人类记忆的芯片,甚至能独立思考的仿生人,现在,随着NVIDIA的project digital发布之后…...
spring-mvc源码分析v3.3.0
分析下springboot内嵌tomcat启动流程,即springboot-mvc <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>3.3.0</version> </dependency>环境…...
反爬风控设计之请求头顺序检测
本次主要讲解请求头的顺序检测的反爬实现, 如下使用Django写的headers请求头顺序检验算法: def index(request):# 获取请求头的顺序request_order list(request.META.keys())print(request_order)# 定义标准请求头顺序standard_order ["HTTP_HO…...
力扣 查找元素的位置
二分查找经典例题。 题目 要是只是从数组中用二分查找对应的元素,套一下模板一下就可以得出了,然后这题就在于其中会有多个目标元素,要用不同的方式在找到第一个元素时再做偏移。 时间复杂度:O(log n),空间复杂度&am…...
Android-V lmkd 中的那些属性值
源码基于:Android V 相关博文: Android lmkd 机制详解(一) Android lmkd 机制详解(二) Android lmkd 机制从R到T 1. 汇总 属性名说明默认值 ro.lmk.debug 启动 lmkd 的debug 模式,会打印一…...