1、快排算法 java
/** * quicksort to sort array * */ public class QuickSort { int partition(double a[], int low, int high) { double tmp = a[low]; int i = low, j = high; while (i < j) { while (i < j && a[j] >= tmp){ j--; } while (i < j && a[i] <= tmp){ i++; } swap(a, i, j); } a[low] = a[i]; a[i] = tmp; return i; } void swap(double a[], int i, int j) { double tmp = a[i]; a[i] = a[j]; a[j] = tmp; } void quickSort(double a[], int low, int high) { if (low < high) { int pos = partition(a, low, high); quickSort(a, low, pos - 1); quickSort(a, pos + 1, high); } } public static void main(String[] args) { QuickSort test = new QuickSort(); double a[] = {1d, 10d, 7d,9d,11d,1d,50d,3d}; test.quickSort(a, 0, a.length - 1); System.out.println(a); } }
2、求中位数算法
/** * 快排找中位数 * 思想:转化成找第K小的数 k = array.length / 2 + 1 * partition分成两边后 * 1、左边个数>K,则继续在左边找 * 2、左边个数<K,则在右边找,此时newK = oldK - 左边个数 * 3、当相等时,则partition得到的pos即是中位数,这种情况分成奇偶两种情况 * a、奇数时直接返回 * b、偶数时要找到该中位数左边区域的最大值 * 最大值分两种情况: * 1、该中位数所在迭代中左边还有数,则取左边的最大值 * 2、该中位数所在迭代中左边无值,则取上回分裂中将该中位数分到右边的分裂点,即程序中的prePart * */ public class QuieckSortMedium { private boolean bOdd;//是否奇偶数 private int kv;//k值 private double medium; int partition(double a[], int low, int high) { double tmp = a[low]; int i = low, j = high; while (i < j) { while (i < j && a[j] >= tmp){ j--; } while (i < j && a[i] <= tmp){ i++; } swap(a, i, j); } a[low] = a[i]; a[i] = tmp; return i; } void swap(double a[], int i, int j) { if(i == j){ return; } double tmp = a[i]; a[i] = a[j]; a[j] = tmp; } void findMedium(double a[]){ bOdd = a.length % 2 == 0; kv = a.length / 2 + 1; medium = 0; findK(a, 0, a.length - 1, kv, -1); } /** * 需求第K小 * @param a * @param low * @param high * @param k * @param prePart 上回分裂中将该中位数分到右边的分裂点 */ void findK(double a[], int low, int high, int k, int prePart){ if(low > high){ return; } int pos = partition(a, low, high); int left = pos - low + 1;//左边个数 if(k > left){//中位数在分裂点右边,将该分裂点作为下次迭代的prePart findK(a, pos + 1, high, k - left, pos); } else if(k < left){//中位数在分裂点左边,本次的prePart作为下次迭代的prePart findK(a, low, pos - 1, k, prePart); } else{ if(bOdd){//偶数时的中位数处理,取两个中位数的均值 double v1 = a[pos]; double v2 = 0; if(low >= pos){ v2 = a[prePart]; //左边无值时取prePart }else{ v2 = findMax(a, low, pos - 1);//左边有值时取左边最大值 } medium = (v1 + v2) / 2; }else{ medium = a[pos]; } } } double findMax(double a[], int low, int high){ double max = a[low]; for(int i = low + 1; i <= high; i ++){ if(a[i] > max){ max = a[i]; } } return max; } double getMedium(){ return medium; } }
3、扩展成求Java的任意对象数组的中位数
import java.util.ArrayList; import java.util.List; /** * 找中位数,使用快排找第K小数算法 * @author wangzejie * * @param <T> */ public class MediumFinder<T extends Comparable<T>> { private boolean bOdd;//是否奇偶数 private int kv;//第几大的值 private List<T> medium = new ArrayList<T>();//中位数数组 /** * 一次quicksort划分两边 * @param a * @param low * @param high * @return */ private int partition(T a[], int low, int high) { T tmp = a[low]; int i = low, j = high; while (i < j) { while (i < j && a[j].compareTo(tmp) >= 0){ j--; } while (i < j && a[i].compareTo(tmp) <= 0){ i++; } swap(a, i, j); } a[low] = a[i]; a[i] = tmp; return i; } /** * 交换数组两个位置的值 * @param a * @param i * @param j */ private void swap(T a[], int i, int j) { if(i == j){ return; } T tmp = a[i]; a[i] = a[j]; a[j] = tmp; } /** * 需求中位值 * @param a * @return 返回中位的T对象,当偶数时返回两点,奇数时返回一点 */ public List<T> findMedium(T a[]){ medium.clear(); if(a.length == 1){ medium.add(a[0]); }else if(a.length == 2){ medium.add(a[0]); medium.add(a[1]); }else{ bOdd = a.length % 2 == 0; kv = a.length / 2 + 1; findK(a, 0, a.length - 1, kv, -1); } return medium; } /** * 寻找第K少的值 * @param a * @param low * @param high * @param k * @param prePart */ private void findK(T a[], int low, int high, int k, int prePart){ if(low > high){ return; } int pos = partition(a, low, high); int left = pos - low + 1; if(k > left){ findK(a, pos + 1, high, k - left, pos); } else if(k < left){ findK(a, low, pos - 1, k, prePart); } else{ if(bOdd){ T v1 = a[pos]; T v2 = null; if(low >= pos){ v2 = a[prePart]; }else{ v2 = findMax(a, low, pos - 1); } medium.add(v1); medium.add(v2); }else{ medium.add(a[pos]); } } } /** * 寻找数组一定范围内的最大值 * @param a * @param low * @param high * @return */ private T findMax(T a[], int low, int high){ T max = a[low]; for(int i = low + 1; i <= high; i ++){ if(a[i].compareTo(max) > 0){ max = a[i]; } } return max; } } public class Point implements Comparable<Point> { private double lng; private double lat; private double value; public double getLng() { return lng; } public void setLng(double lng) { this.lng = lng; } public double getLat() { return lat; } public void setLat(double lat) { this.lat = lat; } public double getValue() { return value; } public void setValue(double value) { this.value = value; } @Override public int compareTo(Point o) { double t = this.value - o.value; if (t > 0) { return 1; } else if (t < 0) { return -1; } return 0; } }
相关推荐
仅供学习使用
内容概要:本文深入探讨了多种高级格兰杰因果检验方法,包括非线性格兰杰因果检验、分位数格兰杰因果检验、混频格兰杰因果检验以及频域因果检验。每种方法都有其独特之处,适用于不同类型的时间序列数据。非线性格兰杰因果检验分为非参数方法、双变量和多元检验,能够在不假设数据分布的情况下处理复杂的关系。分位数格兰杰因果检验则关注不同分位数下的因果关系,尤其适合经济数据的研究。混频格兰杰因果检验解决了不同频率数据之间的因果关系分析问题,而频域因果检验则专注于不同频率成分下的因果关系。文中还提供了具体的Python和R代码示例,帮助读者理解和应用这些方法。 适合人群:从事时间序列分析、经济学、金融学等领域研究的专业人士,尤其是对非线性因果关系感兴趣的学者和技术人员。 使用场景及目标:①研究复杂非线性时间序列数据中的因果关系;②分析不同分位数下的经济变量因果关系;③处理不同频率数据的因果关系;④识别特定频率成分下的因果关系。通过这些方法,研究人员可以获得更全面、细致的因果关系洞察。 阅读建议:由于涉及较多数学公式和编程代码,建议读者具备一定的统计学和编程基础,特别是对时间序列分析有一定了解。同时,建议结合具体案例进行实践操作,以便更好地掌握这些方法的实际应用。
内容概要:本文详细介绍了直流电机双闭环控制系统的原理及其仿真实现。首先构建了一个DC电机的动力学模型,定义了电枢电阻、电感、转矩常数等参数,并通过Python实现了电机的更新机制。接着引入了双环控制器,外环控制转速,内环控制电流,利用PID控制器进行调节。文中强调了电流环和转速环之间的协调关系,以及调参过程中的一些实用技巧,如先调整内环再调整外环,比例先行积分缓。同时提供了MATLAB/Simulink环境下的具体实现步骤,包括设置合理的采样时间和加入必要的滤波器,确保系统的稳定性。此外,还分享了一些常见的错误案例和解决办法,帮助读者更好地理解和应用这一技术。 适合人群:具有一定自动化控制基础,尤其是对电机控制感兴趣的工程技术人员。 使用场景及目标:适用于需要精确控制电机转速和电流的应用场合,如工业机器人、电动汽车等领域。目标是使读者能够掌握双闭环控制的基本原理,并能够在实际项目中灵活运用。 其他说明:文中不仅提供了详细的代码示例,还有丰富的图表辅助解释,便于读者直观理解各个部分的工作原理。对于初学者来说,建议从简单的单环控制入手,逐步过渡到复杂的双环控制。
微信默认视频来电铃声 phonering.mp3
自然语言处理隐私数据集公开收集
咱们期待已久的V2.3.3测试包来啦!大家可以下载体验,帮忙一起测试测试,有啥问题尽管提,咱们一起把它打磨得更完美~
Photo_250404014522.jpeg
内容概要:本文详细介绍了如何使用Matlab 2013进行单相PWM整流电路的双闭环控制仿真,旨在将输入的220V交流电转换为稳定的250V直流电。文章首先解释了单相PWM整流电路的工作原理及其重要性,接着阐述了双闭环控制策略的具体实现方法,包括电压外环和电流内环的设计。随后,文章详细描述了在Matlab Simulink环境中的建模步骤,涵盖了主电路搭建、双闭环控制模块构建以及PWM信号生成的关键环节。最后,通过仿真结果展示了输入电流与输入电压的同步性和输出直流电压的稳定性,并提供了针对常见问题的解决方案。 适合人群:从事电力电子领域的研究人员和技术人员,尤其是对PWM整流电路和Matlab仿真实验感兴趣的读者。 使用场景及目标:适用于高校实验室、科研机构和企业研发中心,帮助相关人员理解和掌握单相PWM整流电路的工作机制及其控制策略,提升电力电子设备的研发效率和性能。 其他说明:文中提供的代码片段和参数设置有助于读者快速上手并进行实验验证,同时也强调了实际应用中需要注意的问题,如滤波电容的选择、PI调节器参数的调整等。
内容概要:本文探讨了云计算和边缘计算的协同系统模型,特别是在该模型下使用线形搜索算法寻找最优路径以及通过多线程并行技术提升系统性能的方法。文中详细介绍了线形搜索算法的Matlab实现及其应用场景,如智能工厂的数据传输路径优化。此外,还讨论了如何在边缘设备上应用多线程并行技术,以充分利用CPU多核能力,提高处理效率。文章强调了在实际部署中需要注意的硬件限制和网络动态变化等问题,并提出了相应的解决策略。 适合人群:对云计算、边缘计算及并行计算感兴趣的开发者和技术研究人员。 使用场景及目标:适用于需要优化云边协同系统中数据传输路径和提升系统性能的实际项目。具体目标包括减少数据传输延迟、提高实时性和处理效率。 其他说明:文章提供了具体的Matlab代码示例,帮助读者更好地理解和实现相关算法。同时提醒读者注意硬件资源的限制,在实际应用中进行适当的调整和优化。
内容概要:本文详细介绍了如何在CATIA DMU模块中进行麦弗逊式独立悬架与齿轮齿条转向器的非参数化运动仿真。首先,文章解释了底盘结构及其运动特性,接着逐步展示了如何设置悬架和转向系统的运动副,包括旋转副、滑动副以及齿轮齿条副的具体配置方法。文中还特别强调了仿真过程中需要注意的技术细节,如参数设置、摩擦系数的选择、运动自由度的限制等。此外,作者分享了一些实用技巧,比如通过正弦函数驱动转向输入、利用传感器监测运动状态、导出并修改仿真动画等。 适合人群:从事汽车工程设计、机械仿真的工程师和技术人员,尤其是熟悉CATIA软件的用户。 使用场景及目标:适用于需要进行车辆转向系统和悬架系统联合仿真的场合,帮助工程师更好地理解和优化车辆动态性能,提高设计效率。 其他说明:文章提供了大量具体的VBA代码片段,便于读者直接应用于自己的项目中。同时,文中提到的一些调试经验和常见问题解决方法也非常有价值。
基于Javaweb(servlet+mysql)
内容概要:本文详细介绍了全桥LLC谐振变换器的设计与仿真,特别是针对高压输入(370-405V)和高功率输出(1000W,25V/40A)的应用场景。文章首先解释了全桥LLC谐振变换器的基础结构及其优势,接着展示了如何通过Python代码计算谐振频率,并通过MATLAB/Simulink进行了详细的电压环PI控制仿真。文中特别强调了PI控制器参数的优化,如比例系数(Kp)和积分系数(Ki)的选择,以及抗积分饱和处理的方法。此外,还探讨了轻载情况下的次谐波振荡问题及其解决方案,如频率钳位和动态调整PI参数。最后,通过仿真数据展示了不同输入电压条件下的性能表现,包括输出电压稳定性、恢复时间和效率。 适合人群:从事电力电子设计、电源管理系统的工程师和技术爱好者,尤其关注高效能电源转换和控制系统的人群。 使用场景及目标:适用于需要设计和优化全桥LLC谐振变换器的工程项目,特别是在高压输入和高功率输出的应用场合。目标是确保输出电压稳定,提高系统效率,并减少开关损耗。 其他说明:文中提供的代码和仿真结果仅为示例,实际应用中需要进一步的理论分析和完善的设计。此外,文中还提及了一些实际调试过程中遇到的问题及解决方案,有助于读者更好地理解和应对类似的技术挑战。
内容概要:本文详细介绍了交错并联Boost PFC电路的设计及其在Simulink中的双闭环控制仿真方法。交错并联Boost电路通过两个Boost模块相位差180度的工作方式,有效降低了输入电流纹波,减轻了元器件的压力。文中重点讨论了输出电压外环和电感电流内环的双闭环控制策略,以及具体的PI参数设置和调优技巧。通过合理的参数选择和控制策略,实现了较低的总谐波失真(THD)和稳定的输出电压。此外,还探讨了仿真过程中常见的问题及解决方案,如电流环带宽设置、积分时间调整、PWM相位同步等。 适合人群:从事电力电子设计、电源管理系统的工程师和技术人员,尤其是对PFC电路和Simulink仿真感兴趣的读者。 使用场景及目标:适用于需要进行PFC电路设计和仿真的场合,旨在提高输入电流质量,减少谐波失真,确保输出电压的稳定性。通过学习本文,读者能够掌握交错并联Boost PFC电路的设计思路和仿真技巧,为实际项目提供理论支持和技术指导。 其他说明:文中提供了详细的MATLAB/Simulink代码片段和参数设置建议,帮助读者更好地理解和应用所介绍的技术。同时,强调了仿真过程中需要注意的关键点,避免常见错误,确保仿真结果的有效性和准确性。
炼石图解网络数据安全管理条例及数据安全合规与技术体系2024630页.pdf
内容概要:本文深入探讨了电动车电驱系统中电机控制器的关键技术——主动阻尼控制及其相关技术的应用。文中介绍了主动阻尼控制的基本概念,即通过一系列控制策略使系统有效抵抗振动,特别是通过转矩补偿和加速度反馈来增强系统的稳定性。作者详细展示了如何利用Matlab二质量模型进行系统动态特性的模拟,并通过巴特沃斯高通滤波器提取转速波动来进行转矩补偿。此外,还讨论了加速度反馈的作用,即通过增加电机惯量来减少振动。最后,文章通过实际案例展示了这些技术的有效性,显著提高了电动车电驱系统的稳定性和可靠性。 适合人群:从事电动车电驱系统开发的技术人员、研究人员及高校相关专业师生。 使用场景及目标:适用于电动车电驱系统的设计与优化,旨在提高系统的稳定性和可靠性,减少振动和噪声,改善驾驶体验。同时,该技术有助于延长传动系统的使用寿命,降低故障率。 其他说明:文章不仅提供了详细的理论和技术背景,还包括具体的代码实现和实际应用案例,便于读者理解和实践。此外,文中提供的仿真模型和详实文档为后续研究和项目优化提供了有力支持。
内容概要:本文深入探讨了增量电导法(Incremental Conductance, INC)在太阳能光伏发电系统最大功率点跟踪(MPPT)中的应用。首先介绍了增量电导法的基本原理及其相对于扰动观测法的优势,特别是其在光照快速变化时的高效性能。接着展示了MATLAB核心代码实现,详细解释了电导变化率的计算以及占空比调整逻辑。随后讨论了Simulink建模的具体步骤和技术细节,如采样周期设定、PWM模块配置等。此外,针对不同应用场景提出了参数调试建议,包括步长选择、温度对步长的影响、负载电流前馈补偿等。最后分享了一些实用经验和注意事项,如避免数值震荡、处理光照突变等。 适合人群:从事光伏系统设计与开发的工程师,尤其是对MPPT算法感兴趣的科研人员和技术爱好者。 使用场景及目标:适用于希望深入了解并掌握增量电导法MPPT技术的研究人员和工程师。主要目标是通过理论讲解和实例代码帮助读者理解增量电导法的工作原理,并能够在MATLAB/Simulink环境中构建高效的MPPT控制系统。 其他说明:文中提供了详细的代码片段和具体的参数设置指导,有助于读者进行实际操作和实验验证。同时强调了在不同条件下(如光照突变、温度变化)的算法优化策略,使系统更加稳健可靠。
内容概要:本文详细探讨了在光伏系统遭遇局部遮荫情况时,扰动观察法(P&O)和粒子群优化算法(PSO)的表现。文中通过Simulink建模,展示了这两种MPPT算法在多峰P-U曲线下的工作原理及其优缺点。具体来说,P&O算法由于其简单的“爬山”策略,在多峰环境下容易陷入局部最优,导致功率大幅震荡;而PSO算法利用粒子群的并行搜索能力,能够更快地找到全局最大功率点,尽管其初始响应稍慢。此外,文章还讨论了不同算法的应用场景以及参数调整的关键点。 适合人群:从事光伏系统设计、优化的研究人员和技术人员,尤其是关注MPPT算法性能提升的专业人士。 使用场景及目标:适用于评估和选择适合特定光伏系统的MPPT算法,特别是在面对复杂光照条件时,帮助决策者确定哪种算法更适合特定应用场景。目标是在提高系统效率的同时降低成本。 阅读建议:读者可以通过对比两种算法的具体实现细节,深入理解各自的优点和局限性,从而为实际工程项目提供有价值的参考。同时,对于想要进一步改进现有算法的开发者,可以借鉴文中提到的一些关键参数设置方法。
内容概要:本文档为《YRC1000 操作要领书_通用・搬运用途篇_2.pdf》,主要介绍了安川电机的工业机器人控制系统。 适合人群:适用于已经购买或计划购买YRC1000系统的工厂技术人员、工程师以及操作员,尤其是那些从事自动化生产线设计、维护和技术支持的专业人士。 使用场景及目标:①帮助用户熟悉YRC1000的基本操作流程,包括示教编程器的功能和使用方法;②指导用户正确设置和执行各种机器人控制命令,确保机器人按照预定路径和任务要求进行工作;③确保用户了解并遵守所有的安全规定,防止意外事故发生;④提供详细的故障排查指南,以便快速解决可能出现。
基于51单片机protues仿真的汽车状态监测和报警系统(仿真图、源代码、AD原理图) 监控胎压,发动机缸压,变速箱温度,转向系统,制动系统,动力蓄电池电压,电机及控制器温度; 汽车状态检测系统 1、检测内容:监控胎压,发动机缸压,变速箱温度,转向系统,制动系统,动力蓄电池电压,电机及控制器温度 2、设置上下限,测量值过限报警 3、除了温度以外,其他传感器均由电位器代替。
内容概要:本文详细介绍了户外储能电源2KW(最大可达3KW)双向逆变器板的生产资料和技术规格。涵盖了从原理图、PCB文件到源代码的完整资料,包括双向软开关DC-DC、SPWM调制、H桥IGBT模块、过流保护等功能的具体实现。文中还提供了详细的硬件选型指导,如IGBT、变压器、电感等元件的选择和参数设定,以及软件部分的关键代码片段,如过流保护、SPWM生成、上电自检等。此外,文章还提到了一些生产和调试过程中需要注意的问题,如变压器绕制、软件烧录、散热器选择等。 适合人群:从事户外储能电源及相关电子产品开发的技术人员,尤其是有一定硬件和嵌入式开发经验的研发人员。 使用场景及目标:帮助开发者快速掌握双向逆变器板的设计和实现细节,缩短产品研发周期,提升产品质量和性能。适用于需要快速推出市场的户外储能电源产品开发。 其他说明:本文不仅提供了完整的生产资料和技术规范,还包括了许多实用的经验和技巧,有助于避免常见错误,确保产品顺利量产。