news 2026/4/17 2:11:21

面试手撕排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
面试手撕排序

手撕排序

(写的时候别忘了关提示,很多时候负面,给我错的代码还分心自己)

(小心别敲错一些变量,算法对了但是结果有问题,顺着逻辑梳理,看变量敲没敲错)

冒泡排序

原理:

扫描比较相邻不按顺序就交换(也可以理解为把第几大的依次放到后面)

packagesort;importjava.util.Scanner;publicclassmaopao{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intn=sc.nextInt(),a[]=newint[n];for(inti=0;i<n;i++){a[i]=sc.nextInt();}for(inti=0;i<n;i++){for(intj=0;j<n-i;j++){if(j!=n-i-1&&a[j]>a[j+1]){inttemp=a[j];a[j]=a[j+1];a[j+1]=temp;}}}for(inti=0;i<n;i++){System.out.print(a[i]+" ");}}}

选择排序

原理:

依次选最几小/大放到前面

packagesort;importjava.util.Scanner;publicclassxuanze{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intn=sc.nextInt(),a[]=newint[n];for(inti=0;i<n;i++){a[i]=sc.nextInt();}for(inti=0;i<n;i++){intmin=Integer.MAX_VALUE,wz=-1;for(intj=i;j<=n-1;j++){if(a[j]<min){min=a[j];wz=j;}}intsum=a[i];a[i]=min;a[wz]=sum;}for(inti=0;i<n;i++){System.out.print(a[i]+" ");}}}

快速排序

原理:

分治+分区,核心是分区,每次选基准值,要保证基准最左边的都比他小,右边的都比他大,可以理解为每次排好基准值对应的那个元素,分治就全排完。

packagesort;importjava.util.Scanner;publicclassquick{staticintn,a[]=newint[100005];publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);n=sc.nextInt();for(inti=0;i<n;i++){a[i]=sc.nextInt();}sort(0,n-1);for(inti=0;i<n;i++){System.out.print(a[i]+" ");}}staticvoidsort(intl,intr){if(l>=r)return;intzj=kp(l,r);sort(l,zj-1);sort(zj+1,r);}staticintkp(intl,intr){intsum=a[l];while(l<r){while(l<r&&a[r]>sum){r--;}if(l<r){a[l]=a[r];l++;}while(l<r&&a[l]<sum){l++;}if(l<r){a[r]=a[l];r--;}}a[l]=sum;returnl;}}

归并排序

原理:

分治+合并两个有序数组,合并细节可能有点麻烦,hot100应该都做过来链表版本的合并吧,这里就是换成了数组,主要也是注意一些边界细节啥的

packageguibing;importjava.util.Scanner;publicclassguibing{staticintn,a[]=newint[100005];publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);n=sc.nextInt();for(inti=0;i<n;i++){a[i]=sc.nextInt();}guib(0,n-1);for(inti=0;i<n;i++){System.out.print(a[i]+" ");}}staticvoidguib(intl,intr){if(l>=r)return;intmid=l+(r-l)/2;guib(l,mid);guib(mid+1,r);intcd1=mid-l+1,cd2=r-mid,az[]=newint[cd1],ar[]=newint[cd2],f1=0,f2=0,qd=l,f3=0,f4=0;for(inti=l;i<=mid;i++){az[f1++]=a[i];}for(inti=mid+1;i<=r;i++){ar[f2++]=a[i];}while(f3<cd1&&f4<cd2){if(az[f3]<=ar[f4]){a[qd++]=az[f3++];}else{a[qd++]=ar[f4++];}}while(f3<cd1){a[qd++]=az[f3++];}while(f4<cd2){a[qd++]=ar[f4++];}}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 16:06:17

JavaEE进阶——SpringAOP从入门到源码全解析

目录 Spring AOP 超详细入门教程&#xff1a;从概念到源码 写给新手的话 1. AOP基础概念&#xff08;先理解思想&#xff09; 1.1 什么是AOP&#xff1f;&#xff08;生活化理解&#xff09; 1.2 AOP核心术语&#xff08;必须掌握&#xff09; 2. Spring AOP快速入门&…

作者头像 李华
网站建设 2026/4/17 12:10:09

SolidWorks装配体与装配图区别介绍

SolidWorks中的“装配体”和“装配图”是两个核心但常被混淆的概念&#xff0c;它们分别处于三维设计流程和二维工程制图两个不同但紧密关联的阶段。深入理解其区别与联系&#xff0c;是掌握现代机械设计流程的关键。 一、核心区别概览 特性维度 装配体​ 装配图​ 本质​ …

作者头像 李华
网站建设 2026/4/16 13:01:23

常用软件工具的使用(2) ---- git 命令进阶 和 github

目录git branchgit branch creategit 查看分支git cherry-pickgit blamegit patchgit rebasegit submodulegithubgithub 创建远程代码仓库github clone 远程仓库到本地github 修改文件提交到本地仓库github push 到远程分支git branch git 分支可以理解为代码的平行世界&#…

作者头像 李华
网站建设 2026/4/17 12:14:14

数据库事务、并发控制与安全机制全解析:原理、实践与避坑指南

数据库事务、并发控制与安全机制全解析&#xff1a;原理、实践与避坑指南 在现代多用户数据库系统中&#xff0c;事务一致性、并发控制、故障恢复和安全访问构成了核心支柱。无论是开发高并发业务系统&#xff0c;还是设计高可用数据架构&#xff0c;深入理解这些机制都至关重要…

作者头像 李华
网站建设 2026/4/16 21:48:57

B样条曲线拟合能量约束方法介绍

B样条曲线拟合中的能量约束方法&#xff08;Unicode公式版&#xff09;1. B样条曲线基本形式B样条曲线由控制点 Pᵢ 和基函数 Nᵢ,ₖ(u) 定义&#xff0c;其表达式为&#xff1a;C(u) Σᵢ₌₀ⁿ Pᵢ Nᵢ,ₖ(u), u ∈ [uₖ, uₘ₋ₖ]其中&#xff1a;k 为阶数&#xff08;次…

作者头像 李华
网站建设 2026/4/16 22:51:52

「旅行商问题 TSP 动态规划 贪心算法 数据结构 Java 代码」

旅行商问题&#xff08;TSP&#xff09;—— 从问题建模到经典算法实现&#xff08;数据结构视角&#xff09;旅行商问题&#xff08;Traveling Salesman Problem, TSP&#xff09;是组合优化领域的经典NP难问题&#xff0c;核心目标是找到一条经过所有城市且仅经过一次、最终回…

作者头像 李华