手写一些常见算法
手写一些常见算法
- 快速排序
- 归并排序
- Dijkstra
- 自定义排序
- 交替打印0和1
- 冒泡排序
- 插入排序
- 堆排序
快速排序
public class Main {public static void main(String[] args) {int nums[] = {1,3,2,5,4,6,8,7,9};quickSort(nums,0,nums.length - 1);}private static void quickSort(int[] nums, int left, int right) {if(left >= right)return;// 划分数组 得到以privot为中心的数组 左小于privot 右大于privotint privot = partition(nums, left, right);// 递归左边和右边quickSort(nums, left, privot - 1);quickSort(nums,privot + 1, right);}private static int partition(int[] nums, int left, int right) {// 选基准int p = nums[right];// 指向大于等于基准元素的前一个位置int l = left - 1;for(int r = 0; r < right; r++){if(nums[r] < p){l++;int tmp = nums[r];nums[r] = nums[l];nums[l] = tmp;}}// 再对基准元素放置l+1处,因为l是指向前一个大于等于基准的位置nums[right] = nums[l + 1];nums[l + 1] = p;return l + 1;}
}
归并排序
public class QuickAndMerge {static int res = 0;public static void main(String[] args) {int nums[] = {1,3,2,5,4,6,8,7,9};int res[] = mergeSort(nums, 0, nums.length - 1);quickSort(nums,0,nums.length - 1);}private static int[] mergeSort(int nums[], int left, int right){// 当排序长度为1,直接返回对应元素if(left == right)return new int[]{nums[left]};// 划分int mid = (right - left)/2 + left;int l[] = mergeSort(nums, left, mid);int r[] = mergeSort(nums, mid + 1, right);return mergeTwoArray(l,r);}private static int[] mergeTwoArray(int l[], int r[]){int res[] = new int[l.length + r.length];int num = 0;int l_num = 0;int r_num = 0;// 依次选取两数组中较小的元素while(l_num < l.length && r_num < r.length){res[num++] = l[l_num] < r[r_num] ? l[l_num++]:r[r_num++];}// 处理剩余元素while(l_num < l.length){res[num++] = l[l_num++];}while(r_num < r.length){res[num++] = r[r_num++];}return res;}
Dijkstra
public class Main{public static void main(String[] args) {int n = Integer.MAX_VALUE/2;int node[] = {1,2,3,4,5};int matrix[][] = new int[node.length + 1][node.length + 1];matrix[1] = new int[]{n, 0, 1, n, 3, n};matrix[2] = new int[]{n, n, 0, 3, 1, n};matrix[3] = new int[]{n, n, n, 0, n, 1};matrix[4] = new int[]{n, n, n, 1, 0, n};matrix[5] = new int[]{n, n, n, n, n, 0};// 求1到其它点的最短距离int distance[] = {n, 0, n, n, n, n};// 每次从一点开始搜索boolean accessed[] = new boolean[node.length + 1];// 共node.length个点for(int i = 0; i < node.length; i++){int curIndex = findMin(distance, accessed);accessed[curIndex] = true;// 如果有更短路径则更新for(int j = 1; j < distance.length; j++){if(curIndex != j && distance[j] > matrix[curIndex][j] + distance[curIndex]){distance[j] = matrix[curIndex][j] + distance[curIndex];}}}System.out.println(distance[5]);}// 找最小distance的一个,易得起始节点到此点的距离已最小,可以开始对其邻居进行访问private static int findMin(int[] distance, boolean[] accessed) {int index = 1;int min = Integer.MAX_VALUE;for(int i = 1; i < distance.length; i++){if(!accessed[i] && min > distance[i]){min = distance[i];index = i;}}return index;}
}
自定义排序
import java.util.Arrays;
import java.util.Comparator;
public class Student{int score;int age;Student(int score, int age){this.score = score;this.age = age;}public int getScore() {return score;}public void setNum(int score) {this.score = score;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public static void main(String[] args) {Student stu[] = new Student[3];stu[0] = new Student(1,2);stu[1] = new Student(1,0);stu[2] = new Student(2,0);// 写法1 匿名内部类Arrays.sort(stu, new Comparator<Student>() {@Overridepublic int compare(Student o1, Student o2) {if(o1.getScore() != o2.getScore())return o2.getScore() - o1.getScore();return o1.getAge() - o2.getAge();}});// 写法2 lambdaArrays.sort(stu, ((o1, o2) -> {if(o1.getScore() != o2.getScore())return o2.getScore() - o1.getScore();return o1.getAge() - o2.getAge();}));// 写法3Arrays.sort(stu, Comparator.comparing(Student::getScore).reversed().thenComparing(Student::getAge));}
}
交替打印0和1
public class Main{private static final Object lock = new Object();private static int count = 0;private static final int MAX = 200;public static void main(String[] args) {// 创建线程 将实现了Runnable接口的printer放入,start启动Thread thread1 = new Thread(new Printer(), "线程1");Thread thread2 = new Thread(new Printer(), "线程2");thread1.start();thread2.start();}static class Printer implements Runnable {// 重写Run方法@Overridepublic void run() {while (true) {// synchronizedsynchronized (lock) {// 打印完成if (count > MAX) {break;}System.out.println(Thread.currentThread().getName() + "打印数字: " + count++);// 唤醒等待锁的线程lock.notify();try {if (count <= MAX) {lock.wait();}} catch (InterruptedException e) {Thread.currentThread().interrupt();}}}}}
}
冒泡排序
public class BubbleSort {public static void main(String[] args) {int bubble[] = {8,7,6,5,4,3,2,1};//bubbleSort(bubble);bubbleSortDesc(bubble);}private static void bubbleSort(int[] bubble) {for(int i = 0; i < bubble.length; i++){int flag = 0;for(int j = 0; j < bubble.length - i - 1; j++){if(bubble[j] < bubble[j + 1]){swap(bubble, j, j + 1);flag = 1;}}if(flag == 0)break;}}private static void bubbleSortDesc(int[] bubble) {for(int i = 0; i < bubble.length; i++){int flag = 0;for(int j = 0; j < bubble.length - i - 1; j++){if(bubble[j] > bubble[j + 1]){swap(bubble, j, j + 1);flag = 1;}}if(flag == 0)break;}}private static void swap(int bubble[], int i, int j){int temp = bubble[i];bubble[i] = bubble[j];bubble[j] = temp;}
}
插入排序
public class InsertSort {public static void main(String[] args) {int insert[] = {1,4,2,6,3,5,8,7};insertSort(insert);}private static void insertSort(int[] insert) {for(int i = 1; i < insert.length; i++){int i2 = i;int temp = insert[i2];while (i2 > 0 && temp < insert[i2 - 1]){insert[i2] = insert[i2 - 1];i2--;}insert[i2] = temp;}}
}
堆排序
public class HeapSort {public static void main(String[] args) {int nums[] = {1,3,4,2,6,5};heapSort(nums);}public static void heapSort(int[] nums) {int n = nums.length;// 挑整数组位置,使得父节点大于子节点,从最后一个非叶子节点开始for (int i = n / 2 - 1; i >= 0; i--) {adjust(nums, n, i);}// 依次从堆中提取元素,for (int i = n - 1; i > 0; i--) {// 将当前父节点移动到末尾int tmp = nums[0];nums[0] = nums[i];nums[i] = tmp;// 移动到末尾后继续调整堆adjust(nums, i, 0);}}private static void adjust(int[] nums, int n, int i) {// i表示父节点int largest = i;int left = 2 * i + 1; // 左子节点int right = 2 * i + 2; // 右子节点// 如果左子节点大于根节点if (left < n && nums[left] > nums[largest]) {largest = left;}// 如果右子节点大于当前最大值if (right < n && nums[right] > nums[largest]) {largest = right;}// 如果最大值不是根节点 交换节点位置,使得较大一方到父节点位置if (largest != i) {int tmp = nums[i];nums[i] = nums[largest];nums[largest] = tmp;// 调整交换后子节点所在的子树adjust(nums, n, largest);}}
}
相关文章:
手写一些常见算法
手写一些常见算法 快速排序归并排序Dijkstra自定义排序交替打印0和1冒泡排序插入排序堆排序 快速排序 public class Main {public static void main(String[] args) {int nums[] {1,3,2,5,4,6,8,7,9};quickSort(nums,0,nums.length - 1);}private static void quickSort(int[…...
使用DeepSeek完成一个简单嵌入式开发
开启DeepSeek对话 请帮我使用Altium Designer设计原理图、PCB,使用keil完成代码编写;要求:使用stm32F103RCT6为主控芯片,控制3个流水灯的原理图 这里需要注意,每次DeepSeek的回答都不太一样。 DeepSeek回答 以下是使…...
每日一题之储存晶体
问题描述 威慑纪元 2230 年,人类联邦在与三体文明的对抗中,为了强化飞船的能源储备,决定收集能量晶体。飞船的储存空间呈矩形,边长分别为 a 和 b。对于一个能量晶体,只有当它的长度小于或等于存储空间的对角线长度时&…...
关于我和快速幂的事()
我之前只会这样的(dfs): 不懂下面这种写法的具体逻辑: 看完下面的推理,再转转我聪明的小老戴: 法一中:把2^11看成(2^5)^2 法二中:把2^11看成(2^2)^5...
【鸿蒙开发】Hi3861学习笔记- GPIO之直流电机
00. 目录 文章目录 00. 目录01. GPIO概述02. 直流电机概述03. ULN2003模块概述04. 硬件设计05. 软件设计06. 实验现象07. 附录 01. GPIO概述 GPIO(General-purpose input/output)即通用型输入输出。通常,GPIO控制器通过分组的方式管理所有GP…...
mapbox高阶,结合threejs(threebox)添加extrusion挤出几何体,并添加侧面窗户贴图和楼顶贴图,同时添加真实光照投影
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️threebox extrusion挤出几何体1.3 ☘️…...
【蓝桥杯速成】| 2.逆向思维
题目一:青蛙跳台阶 题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。 求该青蛙跳上一个 n 级的台阶总共有多少种跳法。 解题步骤 选用递归的方法解决该问题! 使用递归只需要考虑清楚边界条件/终止条件,再写清楚单层…...
halcon机器人视觉(四)calibrate_hand_eye_stationary_3d_sensor
目录 一、准备数据和模型二、按照表面匹配的的结果进行手眼标定三、根据标定结果计算CalObjInCamPose一、准备数据和模型 1、读3D模型:read_object_model_3d 2、创建表面匹配模板:create_surface_model 3、创建一个HALCON校准数据模型:create_calib_data read_object_mode…...
python-leetcode-叶子相似的树
872. 叶子相似的树 - 力扣(LeetCode) 下面是一个完整的 Python 函数,接收两个二叉树的根节点 root1 和 root2,返回它们是否叶相似。 代码实现 class TreeNode:def __init__(self, val0, leftNone, rightNone):self.val valself…...
<03.13>八股文补充知识
import java.lang.reflect.*; public class Main {public static void main(String[] args) throws Exception {// 获取 Class 对象//1. 通过类字面量Class<?> clazz Person.class;//2 通过对象实例化String str "Hello";Class<?> clazz_str str.ge…...
GraphRAG 融合 RAG:双剑合璧,精度更上一层楼
检索增强生成 (Retrieval-Augmented Generation, RAG) 已成为构建知识密集型 NLP 应用的标准范式。RAG 通过结合大型语言模型 (LLM) 的生成能力和外部知识库的检索能力,显著提升了生成结果的质量。然而,在某些场景下,仅依靠传统的 RAG 或 GraphRAG 可能无法达到最佳效果。本…...
ffmpeg + opencv 打静态库编译到可执行文件中
下载ffmpeg ,我下载的为6.0 版本,解压后执行: ./configure --enable-static --disable-shared --pkg-config-flags=“–static” --extra-cflags=“-fPIC” --extra-cxxflags=“-fPIC” --prefix=/usr/local2.等待配置完成,执行 make && make install 进行编译安装…...
2025探索短剧行业新可能报告40+份汇总解读|附PDF下载
原文链接:https://tecdat.cn/?p41043 近年来,短剧以其紧凑的剧情、碎片化的观看体验,迅速吸引了大量用户。百度作为互联网巨头,在短剧领域积极布局。从早期建立行业专属模型冷启动,到如今构建完整的商业生态…...
前端面试:如何实现预览 PDF 文件?
在前端开发中,实现 PDF 文件的预览是一个常见需求,尤其是在应用程序中需要用户查看文档时。以下是几种常见的方法,可以用来实现在网页中预览 PDF 文件: 方法一:使用 <iframe> 标签 1. 基本实现 最简单的方式是…...
STM32 内置的通讯协议
数据是以帧为单位发的 USART和UART的区别就是有没有同步功能 同步是两端设备有时钟连接,异步是没时钟连接,靠约定号的频率(波特率)接收发送数据 RTS和CTS是用来给外界发送已“可接收”或“可发送”信号的,一般用不到…...
一个简单的PHP框架
原文地址:一个简单的PHP框架 更多内容请关注:智想天开 框架概述 一个基本的 PHP 框架通常包含以下几个部分: 前端控制器(Front Controller):处理所有的 HTTP 请求,统一入口。 路由器…...
什么是SpringCloud?为何要选择SpringCloud?
什么是 Spring Cloud? Spring Cloud 是一套基于 Spring Boot 构建的 微服务架构解决方案,提供了一整套微服务开发所需的组件,如服务注册与发现、配置管理、负载均衡、熔断机制、网关等。它基于 Spring 生态系统,简化了分布式系统…...
信息安全访问控制、抗攻击技术、安全体系和评估(高软42)
系列文章目录 信息安全访问控制、抗攻击技术、安全体系和评估 文章目录 系列文章目录前言一、信息安全技术1.访问控制2.抗攻击技术 二、欺骗技术1.ARP欺骗2.DNS欺骗3.IP欺骗 三、抗攻击技术1.端口扫描2.强化TCP/IP堆栈 四、保证体系和评估1.保证体系2.安全风险管理 五、真题在…...
晋升系列4:学习方法
每一个成功的人,都是从底层开始打怪,不断的总结经验,一步一步打上来的。在这个过程中需要坚持、总结方法论。 对一件事情长久坚持的人其实比较少,在坚持的人中,不断的总结优化的更少,所以最终达到高级别的…...
脑电波控制设备:基于典型相关分析(CCA)的脑机接口频率精准解码方法
文章目录 前言一、CCA的用途二、频率求解思路三、输入数据结构四、判断方法五、matlab实践1.数据集获取及处理2.matlab代码3.运行及结果 六、参考文献 前言 在脑机接口(BCI)领域,有SSVEP方向,中文叫做稳态视觉诱发电位,当人观看闪烁的视觉刺激…...
Android Spinner总结
文章目录 Android Spinner总结概述简单使用自定义布局自定义Adapter添加分割线源码下载 Android Spinner总结 概述 在 Android 中,Spinner 是一个下拉选择框。 简单使用 xml布局: <Spinnerandroid:id"id/spinner1"android:layout_width&…...
element-ui layout 组件源码分享
layout 布局组件源码分享,主要从以下两个方面: 1、row 组件属性。 2、col 组件属性。 一、row 组件属性。 1.1 gutter 栅栏间隔,类型为 number,默认 0。 1.2 type 布局模式,可选 flex,现代浏览器下有效…...
OBJ文件生成PCD文件(python 实现)
代码实现 将 .obj 文件转换为 .pcd(点云数据) 代码文件。 import open3d as o3d# 加载 .obj 文件 mesh o3d.io.read_triangle_mesh("bunny.obj")# 检查是否成功加载 if not mesh.has_vertices():print("无法加载 .obj 文件,…...
LinPEAS 使用最佳实践指南
在渗透测试和权限提升评估中,LinPEAS(Linux Privilege Escalation Awesome Script)是⼀个⽤来搜索类unix主机上可能的提权路径的⾃动化脚本。本文将介绍使用 LinPEAS 的最佳实践方案,并针对不同环境(如无 curl 的情况&…...
c++介绍智能指针 十二(1)
普通指针:指向内存区域的地址变量。使用普通指针容易出现一些程序错误。 如果一个指针所指向的内存区域是动态分配的,那么这个指针变量离开了所在的作用域,这块内存也不会自动销毁。动态内存不进行释放就会导致内存泄露。如果一个指针指向已…...
Vue的scoped原理是什么?
scoped的工作原理 当在 <style> 标签上使用 scoped 属性时,Vue 会为当前组件的每个元素添加一个唯一的 data-v-xxxxxx 属性,并将样式规则中的选择器修改为包含该属性的形式。 编译阶段: 在编译 .vue 文件时,Vue 的编译器…...
大白话解释 React 中高阶组件(HOC)的概念和应用场景,并实现一个简单的 HOC。
高阶组件(HOC)的概念 在 React 里,高阶组件(Higher-Order Component,简称 HOC)就像是一个“超级工厂函数”。它本身是一个函数,而且这个函数接收一个组件作为参数,然后返回一个新的…...
深入浅出C++ STL:统领STL全局
深入浅出C STL:统领STL全局 深入浅出C STL:统领STL全局github主页地址前言一、STL的前世今生1.1 什么是STL?1.2 STL版本演进 二、STL六大核心组件详解2.1 容器(Containers)容器性能对照表 2.2 算法(Algorit…...
k8s面试题总结(十五)
1.如何使用Kubernetes进行多环境部署(如开发,测试和生产环境)? 使用命名空间(namespaces): 命名空间是用于逻辑隔离和资源分组的一种方式,可以为每个环境创建单独的命名空间。 2.使…...
Appium等待机制--强制等待、隐式等待、显式等待
书接上回,Appium高级操作--其他操作-CSDN博客文章浏览阅读182次,点赞6次,收藏7次。书接上回Appium高级操作--从源码角度解析--模拟复杂手势操作-CSDN博客。https://blog.csdn.net/fantasy_4/article/details/146162851主要讲解了Appium的一些…...
