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

算法练习-排序(一)

算法练习-排序(一)

文章目录

  • 算法练习-排序(一)
    • 1 排序算法
      • 1.1 冒泡排序
        • 1.1.1代码
      • 1.2插入排序
        • 1.2.1代码
      • 1.3 选择排序
        • 1.3.1代码
      • 1.4归并排序
        • 1.4.1代码
      • 1.5 快速排序
        • 1.5.1 思路
        • 1.5.2 代码
    • 2 题目
      • 2.1 特殊排序
        • 2.1.1 题目
        • 2.1.2 题解
      • 2.2 数组中的第k个最大元素
        • 2.2.1 题目
        • 2.2.2 题解
      • 2.3 对链表进行插入排序
        • 2.3.1 题目
        • 2.3.2 题解
      • 2.4 排序预处理
        • 2.4.1 题目

1 排序算法

1.1 冒泡排序

1.1.1代码

void bubbleSort(int[] a, int n) {if (n <= 1) return;for (int i = 0; i < n; i++) { // 第几趟冒泡boolean flag = false;for (int j = 0; j < n - i - 1; j++) {if (a[j] > a[j + 1]) {int tmp = a[j];a[j] = a[j + 1];a[j + 1] = tmp;flag = true; // 表示有数据交换}}if (!flag) break;}
}

1.2插入排序

1.2.1代码

public static void InsertSort(int[] a, int n) {if (n <= 1) return;for (int i = 1; i < n; i++) {int value = a[i];for (int j = i - 1; j >= 0; --j) {if (a[j] > value) {a[j + 1] = a[j];} else {break;}}a[j + 1] = value;}
}

1.3 选择排序

1.3.1代码

public void selectionSort(int[] a, int n) {if (n <= 1) return;for (int i = 0; i < n - 1; i++) {int minPos = i;for (int j = i; j < n; j++) {if (a[j] < a[minPos]) {minPos = j;}}int tmp = a[i];a[i] = a[minPos];a[minPos] = tmp;}
}

1.4归并排序

1.4.1代码

public void mergeSort(int[] a, int n) {mergeSort_r(a, 0, n - 1);
}private void mergeSort_r(int[] a, int p, int r) {if (p >= r) return;int q = p + (r - q) / 2;mergeSort_r(a, p, q);mergeSort_r(a, q + 1, r);merge(a, p, q, r);
}private void merge(int[] a, int p, int q, int r) {int i = p;int j = q + 1;int k = 0;int[] tmp = new int[r - q + 1];while (i <= q && j <= r) {if (a[i] <= a[j]) {tmp[k++] = a[i++];} else {tmp[k++] = a[j++];}}while (i <= q) {tmp[k++] = a[i++];}while (j <= r) {tmp[k++] = a[j++];}for (int i = 0; i < r - p; i++) {a[p + i] = tmp[i];}
}

1.5 快速排序

1.5.1 思路

先把数组中的一个数当作基准数,一般把数组最左面的数当作基准数,然后从两边进行检索。

先从右边检索比基准数小的,再从左边检索比基准数大的。

如果检索到了,就停下,交换这两个元素,然后继续检索

两个指针一旦相遇就停止检索,将基准数和相遇位置进行交换

1.5.2 代码

public static void quickSort(int[] a, int n) {quickSort_r(a, 0, n - 1);
}private void swap(int[] nums, int i ,int j) {int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;
}public static void quickSort_r(int[] arr, int left, int right) {if (left >= right) return;// 定义变量保存基准数int base = arr[left];// 定义变量i,指向最左边int i = left;// 定义变量j,指向最右边int j = right;//  当i和j不相遇时,在循环中进行检索while (i != j) {// 现由j从右往左检索while (arr[j] >= base && i < j) j--;while (arr[i] <= base && i < j) i++;// i 和 j都停下了,交换 i 和 j 位置的元素swap(arr, i, j);}swap(arr, left, i);quickSort_r(arr, left, i - 1);quickSort_r(arr, j + 1, right);}
public static void quickSort(int[] a, int n) {quickSort_r(a, 0, n - 1);
}private static void quickSort_r(int[] a, int p, int r) {if (p >= r) return;int q = partition(a, p, r);quickSort_r(a, p, q - 1);quickSort_r(a, q + 1, r);
}private static int partition(int[] a, int p, int r) {int i = p - 1; // [p, i]表示小于pivot值的元素for (int j = p; j < r; j++) {if (a[j] < a[r]) {swap(a, i + 1, j);i++;}}swap(a, i + 1, r);return i + 1;
}private void swap(int[] nums, int i, int j) {int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;
}

2 题目

2.1 特殊排序

2.1.1 题目

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分

2.1.2 题解

class Solution {public int[] exchange(int[] nums) {int i = 0;int j = nums.length - 1;while (i < j) {if (nums[i] % 2 == 1) {i++;continue;}if (nums[j] % 2 == 0) {j--;continue;}int tmp = nums[j];nums[i] = nums[j];nums[j] = tmp;i++;j--;}return nums;}
}

2.2 数组中的第k个最大元素

链接:https://leetcode.cn/problems/kth-largest-element-in-an-array

2.2.1 题目

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入: [3,2,1,5,6,4], k = 2
输出: 5
示例 2:

输入: [3,2,3,1,2,4,5,5,6], k = 4
输出: 4

2.2.2 题解

class Solution {public int findKthLargest(int[] nums, int k) {if (nums.length < k) return -1;return quickSort(nums, 0, nums.length - 1, k);}private int quickSort(int[] nums, int p, int r, int k) {if (p > r) return -1;int q = partition(nums, p ,r);if (q - p + 1 == k) {return nums[q];} else if (q - p + 1 < k) {return quickSort(nums, q + 1, r, k - (q - p + 1));} else {return quickSort(nums, p, q - 1, k);}}private int partition(int[] nums, int p, int r) {int i = p;int j = r - 1;while (i < j) {while (i < j && nums[i] > nums[r]) {i++;}while (i < j && nums[j] <= nums[r]) {j--;}if (i < j) {swap(nums, i, j);i++;j--;}}if (j >= p && nums[j] < nums[r]) {swap(nums, j , r);return j;} else {swap(nums, j + 1, r);return j + 1;}}private void swap(int[] arr, int i, int j) {int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}
}
class Solution {public int findKthLargest(int[] nums, int k) {if (nums.length < k) return -1;return quickSort(nums, 0, nums.length - 1, k);}private int quickSort(int[] nums, int p, int r, int k) {if (p > r) return -1;int q = partition(nums, p ,r);if (q - p + 1 == k) {return nums[q];} else if (q - p + 1 < k) {return quickSort(nums, q + 1, r, k - (q - p + 1));} else {return quickSort(nums, p, q - 1, k);}}private int partition(int[] nums, int p, int r) {int i = p - 1; // [p, i]表示小于pivot值的元素for (int j = p; j < r; j++) {if (nums[j] > nums[r]) {swap(nums, i + 1, j);i++;}}swap(nums, i + 1, r);return i + 1;}private void swap(int[] arr, int i, int j) {int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}
}

2.3 对链表进行插入排序

链接:https://leetcode.cn/problems/insertion-sort-list

2.3.1 题目

给定单个链表的头 head ,使用 插入排序 对链表进行排序,并返回 排序后链表的头 。

插入排序 算法的步骤:

插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。
每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。
重复直到所有输入数据插入完为止。
下面是插入排序算法的一个图形示例。部分排序的列表(黑色)最初只包含列表中的第一个元素。每次迭代时,从输入数据中删除一个元素(红色),并就地插入已排序的列表中。

对链表进行插入排序。

示例 1:

请添加图片描述

输入: head = [4,2,1,3]
输出: [1,2,3,4]
示例 2:

请添加图片描述

输入: head = [-1,5,3,4,0]
输出: [-1,0,3,4,5]

2.3.2 题解

class Solution {public ListNode insertionSortList(ListNode head) {if (head == null) return null;// 存储已经排序好的节点ListNode newHead = new ListNode(Integer.MIN_VALUE, null);// 遍历节点ListNode p = head;while (p != null) {ListNode tmp = p.next;// 寻找p节点插入的位置,插入到哪个节点后面ListNode q = newHead;while (q.next != null && q.next.val <= p.val) {q = q.next;}p.next = q.next;q.next = p;p = tmp;}return newHead.next;}
}

2.4 排序预处理

2.4.1 题目

有一组无序数据,找到出现次数最多的数据

public int maxCount(int[] data) {Arrays.sort(data);int n = data.length;int pre = -1;int count = 0;int max = -1;for (int i = 0; i < n; ++i) {if (data[i] == pre) {count++;if (max < count) max = count;} else {count = 1;pre = data[i];if (max < count) max = count;}}return max;
}

相关文章:

算法练习-排序(一)

算法练习-排序(一) 文章目录算法练习-排序(一)1 排序算法1.1 冒泡排序1.1.1代码1.2插入排序1.2.1代码1.3 选择排序1.3.1代码1.4归并排序1.4.1代码1.5 快速排序1.5.1 思路1.5.2 代码2 题目2.1 特殊排序2.1.1 题目2.1.2 题解2.2 数组中的第k个最大元素2.2.1 题目2.2.2 题解2.3 对…...

CentOS7.6快速安装Docker

快速安装 官网安装参考手册&#xff1a;https://docs.docker.com/install/linux/docker-ce/centos/ 确定你是CentOS7及以上版本,yum是在线安装! [rootVM-4-5-centos ~]# cat /etc/redhat-releaseCentOS Linux release 7.6.1810 (Core)接下来您只管自上向下执行命令即可&#x…...

CentOS 7安装N卡驱动和CUDA和cuDNN

前言系统一开始是CentOS 7.6&#xff0c;安装依赖时yum给的内核文件的版本号和uname -r的结果不一样&#xff0c;这时不能直接装依赖&#xff0c;装上后后面装驱动时会报错找不到内核头文件(最开始我直接装依赖了&#xff0c;以为高版本兼容低版本&#xff0c;然后装驱动时报错…...

Java开发 - 分页查询初体验

前言在上一篇&#xff0c;我们对es进行了深入讲解&#xff0c;相信看过的小伙伴已经能基本掌握es的使用方法&#xff0c;我们知道&#xff0c;es主要针对的是搜索条件&#xff0c;在这方面es具有无可比拟的优势&#xff0c;但我们也会注意到&#xff0c;有时候搜索条件过于宽泛…...

C语言循环语句do while和嵌套循环语句讲解

C do…while 循环 不像 for 和 while 循环&#xff0c;它们是在循环头部测试循环条件。在 C 语言中&#xff0c;do…while 循环是在循环的尾部检查它的条件。 do…while 循环与 while 循环类似&#xff0c;但是 do…while 循环会确保至少执行一次循环。 语法 C 语言中 do…w…...

【计算机视觉】OpenCV 4高级编程与项目实战(Python版)【7】:拼接图像

我们已经知道,图像是通过数组描述的,那么拼接图像其实就是拼接数组。NumPy提供了2个拼接数组的函数,分别是hstack函数和vstack函数,这两个拼接函数可以将两个数组水平和垂直拼接在一起,也就相当于将两幅图像水平和垂直拼接在一起,本节将详细讲解如何使用这两个函数水平拼…...

王道操作系统课代表 - 考研计算机 第二章 进程与线程 究极精华总结笔记

本篇博客是考研期间学习王道课程 传送门 的笔记&#xff0c;以及一整年里对 操作系统 知识点的理解的总结。希望对新一届的计算机考研人提供帮助&#xff01;&#xff01;&#xff01; 关于对 “进程与线程” 章节知识点总结的十分全面&#xff0c;涵括了《操作系统》课程里的全…...

C++修炼之练气期三层——函数重载

目录 1.引例 2.函数重载的概念 3.C支持函数重载的原理 1.引例 倘若现在要实现一个加法计算器&#xff0c;用C语言实现的话我们会选择这样的方式&#xff1a; int Add_int(int a, int b) {return a b; }double Add_double(double a, double b) {return a b; } 在使用加…...

在linux上运行jar程序操作记录

1.文件传送 使用ftp把打包后的项目jar包上传到linux服务器的目录上(这里有两个文件&#xff0c;一个pengning.jar&#xff0c;一个配置文件application.yml&#xff09; 2.进入目录并运行程序 打开终端&#xff0c;进入pengning.jar所在的目录 [rootcampus /]# [rootcampu…...

【STM32】入门(十二):实时操作系统RTOS和通用操作系统GPOS的区别

1、简述 实时操作系统(RTOS&#xff0c;Real Time Operating System) 通用操作系统(GPOS&#xff0c;General Purpose Operating System) 2、区别 1&#xff09;任务 实时操作系统&#xff1a;使用分时设计&#xff0c;其中每个任务被分配一小段时间&#xff0c;在切换到另一…...

2023-3-1刷题情况

在网格图中访问一个格子的最少时间 题目描述 给你一个 m x n 的矩阵 grid &#xff0c;每个元素都为 非负 整数&#xff0c;其中 grid[row][col] 表示可以访问格子 (row, col) 的 最早 时间。也就是说当你访问格子 (row, col) 时&#xff0c;最少已经经过的时间为 grid[row][…...

Web前端学习:五 - 练习

四二-四八&#xff1a;baidu糯米 44-48 1、写法1 &#xff08;1&#xff09;a.movie1 .Navigation .recommend .listbanner a.movie1{background: url(img/h_1.jpg) no-repeat 63px 9px;}表示a标签且class为movie1的元素 如&#xff1a; <a href"#" class&quo…...

软件测试之测试用例设计方法—等价类划分法

测试用例设计方法—等价类划分法 掌握常用测试用例设计方法,再结合测试用例的要素能给快速的实现测试用例的设计和编写.但是由于软件系统大小的不同我们不可能把所有的单个或组合的情况都进行测试,所以我们测试时应该根据不同的场景设计不同的测试用例,尽可能的覆盖到全部需要…...

gdb常用命令详解

gdb常用调试命令概览和说明 run命令 在默认情况下&#xff0c;gdbfilename只是attach到一个调试文件&#xff0c;并没有启动这个程序&#xff0c;我们需要输入run命令启动这个程序&#xff08;run命令被简写成r&#xff09;。如果程序已经启动&#xff0c;则再次输入 run 命令…...

2022 年江西省职业院校技能大赛高职组“信息安全管理与评估”赛项样题

2022 年江西省职业院校技能大赛高职组 “信息安全管理与评估”赛项样题 一、 赛项信息 第一场比赛&#xff1a; 竞赛阶段 任务阶 段 竞赛任务 竞赛时 间 分值 第一阶段 任务 1 网络平台搭建 90 平台搭建与安全 任务 2 网络安全设备配置与防护 210 设备配置防护…...

射频调试的习惯

三月开工了&#xff0c;一个月的调试即将开始。其实调试的重心是测试&#xff0c;核心的推动力是做事的习惯和思维。测试很重要&#xff0c;数据不对&#xff0c;能力和时间都浪费了上面了。测试的问题初步解完了&#xff0c;今天吃饭的时候碰到大领导。领导好忙&#xff0c;我…...

centos7上安装mysql8.0

1、检查一下自己电脑上安装了哪些mysql [rootlocalhost ~]# find / -name mysql 2、把安装的mysql全部删掉 [rootlocalhost ~]# rm -rf /usr/lib64/mysql/ [rootlocalhost ~]# rm -rf /usr/local/mysql/ [rootlocalhost ~]# rm -rf /etc/selinux/targeted/active/modules/100…...

如何使用BackupOperatorToDA将Backup Operators用户权限提升为域管理员

关于BackupOperatorToDA BackupOperatorToDA是一款功能强大的红队提权工具&#xff0c;该工具能够在不使用域控制器RDP或WinRM的情况下&#xff0c;帮助广大研究人员将Backup Operators组的成员账号提升为域管理员权限。 如果红队研究人员在渗透测试的过程中&#xff0c;拿到…...

百度文心大模型开发者斩获CCF BDCI大赛唯一『最佳算法能力奖』

‍2023年2月24日至25日&#xff0c;中国计算机学会&#xff08;CCF&#xff09;主办、苏州市吴江区人民政府支持&#xff0c;苏州市吴江区工信局、吴江区东太湖度假区管理办公室、苏州市吴江区科技局、CCF大数据专家委员会及其他专业委员会等多家组织单位共同承办的大数据与AI领…...

合宙Air780E|硬件元数据|LuatOS-SOC接口|官方demo|学习(21):hmeta(本库尚在开发中)

基础资料 基于Air780E开发板&#xff1a;Air780E文档中心 简介&#xff1a;CSDK开发 探讨重点 本系列主要探讨利用合宙平台进行fota_iot差分包升级的基本操作、编译及上传&#xff0c;升级等操作。 硬件准备 Air780E开发板1块&#xff0c;SIM卡1张。 ​内容参考 官方wi…...

Educational Codeforces Round 144 (Rated for Div. 2) (A-C)

文章目录A. Typical Interview Problem【找规律&#xff0c;暴力】B. Asterisk-Minor Template【分类、模拟】C. Maximum Set【数学】A. Typical Interview Problem【找规律&#xff0c;暴力】 链接 传送门 分析 3 5 6 9 10 12 15||||||| 15 3 15 5 ………… F B F F B F FB…...

机器学习100天(三十三):033 KD树的Python实现

《机器学习100天》完整目录:目录 机器学习100天,今天讲的是:KD 树的Python实现! 打开 spyder,我们新建一个 kd_tree.py 脚本。首先,我们新建一个类,名为Node,它定义了 KD 树节点中包含的数据结构。例如数据、深度、左节点、右节点。 # KD树结点中包含的数据结构 clas…...

matlab-数据和数据运算

学习视频基本数据类型1.1 整型与浮点型在matlab中同样有8、16、32、64bit的数据大小之分&#xff0c;同时也可以叠加signed(有符号)和unsigned(无符号)的区别&#xff0c;默认数据类型为double(双精度浮点型)参考其他博客的详述1.2 复数还有一些其他常用的函数方法&#xff1a;…...

怕被AI取代快想办法“攒”个“数字第二大脑”

每日经济新闻发文:来自央视财经微博2月27日消息,美国《财富》杂志网站近日报道,美国一家提供就业服务的平台对1000家企业进行了调查。结果显示,美国最新调查显示50%企业已在用ChatGPT,其中48%已让其代替员工,有公司省下10多万美元!还有30%表示,有计划使用。...

【zlkmedia】rtp处理代码走读

zlkmedia的特点就是专门为安防定制了一系列直播、rtc相关流媒体协议处理rtp包的处理是贯穿始终的。本文是阅读rtp包处理代码的笔记。服务器收到rtp包 D:\XTRANS\ZLMIA\ZLMediaKit-offical\src\Rtp\RtpServer.cppvoid onRecvRtp(const Socket::Ptr &sock, const Buffer::Ptr…...

SSM SpringBoot vue 在线教学质量评价系统

SSM SpringBoot vue 在线教学质量评价系统 SSM 在线教学质量评价系统 功能介绍 首页 图片轮播展示 登录 学生注册 教师注册 督导注册 教师展示 教师详情 学生评价 课程信息 课程详情 提交选修该课 学生选课 学生留言 个人中心 后台管理 管理员或学生或教师或督导登录 个人中…...

如何使用Codecepticon对C#、VBA宏和PowerShell源代码进行混淆处理

关于Codecepticon Codecepticon是一款功能强大的代码混淆处理工具&#xff0c;该工具专为红队和紫队渗透测试安全活动而开发&#xff0c;在该工具的帮助下&#xff0c;广大研究人员可以轻松对C#、VBA5/VBA6&#xff08;宏&#xff09;和PowerShell源代码进行混淆处理。Codecep…...

delphi fmx android11,12删除照片

最近用fmx在研究照片管理 在删除照片时出现报错 has no access to content 后面得知,android系统11开始强制启用Scoped Storage分区存储 前言: android系统对于媒体文件的修改在代码和应用层面的不同,将取决于分区存储是否启用: Android10开始引入Scoped Storage分区存储 ,…...

Android - API对应版本名称

APIAndroid版本名称3414.0UpsideDownCake3313.0Tiramisu3212.0Sv23112.0S3011.0R2910.0Q289.0Pie278.1Oreo268.0Oreo257.1Nougat247.0Nougat236.0Marshmallow225.1LOLLIPOP_MR1215.0LOLLIPOP194.4KITKAT194.4KITKAT184.3JELLY_BEAN_MR2174.2/4.2.2JELLY_BEAN_MR1164.1/4.1.1JEL…...

22.3.1 Educational Codeforces Round 144 (Rated for Div. 2) A~C

A题 题目链接: https://codeforces.com/contest/1796/problem/A 题解: 感觉就是阅读理解题, 3和5的公倍数出现有规律(嫌麻烦可以直接先算出1~1000的s)然后直接一个string的find函数就解决了, 注意一下find函数如果搜不到返回之是npos(-1) /* ⣿⣿⣿⣿⣿⣿⡷⣯⢿⣿⣷⣻⢯⣿⡽…...

外贸流程的基本流程图/廊坊百度关键词优化

问题&#xff1a;项目运行后出现“目标进程已退出&#xff0c;但未引发 CoreCLR 启动事件。请确保将目标进程配置为使用 .NET Core。如果目标进程未运行 .NET Core&#xff0c;则发生这种情况并不意外。 程序“[16780] dotnet.exe”已退出&#xff0c;返回值为 -2147450730 (0x…...

做网站的外包公司上班好不好/seochan是什么意思

背景: 因为移动端APP和Msite手机注册发送短信验证码没有添加图片验证码功能。公司的短信接口被恶意刷取。所以我们就觉得在移动端添加一个图片验证码功能。分享一下大体实现方式思路。PS demo是自己写的。跟公司代码还是有很大差距的。 一. 图片验证码第一版    1. 建立图片…...

东莞市哪里有做网站公司/百度排名服务

NPDP认证是由美国产品开发管理协会(PDMA)颁发的新产品开发专业认证。此认证的核心价值在于整合产品开发管理的理论与实践&#xff0c;包含新产品开发策略、研发流程管理、 市场研究、营销规划、团队管理、项目管理等等&#xff0c;PDMA将其整合为一套完整的产品开发管理知识体系…...

兴国做网站/上首页seo

小程序的视图与渲染 组件的基本使用 在官方文档当中&#xff0c;我们可以找到组件一栏&#xff0c;在那里就可以学习到基本组件的使用了。 数据绑定 在.wxss中通过{{}}就可以定义数据的变量名称&#xff0c;而在.js文件中的data就可以对数据进行初始化&#xff0c;这就完成…...

网络推广发展/杭州seo推广公司

zookeeper是干嘛的呢 Zookeeper的作用1.可以为客户端管理少量的数据kvkey&#xff1a;是以路径的形式表示的&#xff0c;那就意味着&#xff0c;各key之间有父子关系&#xff0c;比如/ 是顶层key用户建的key只能在/ 下作为子节点&#xff0c;比如建一个key&#xff1a; /aa 这个…...

wordpress nginx cos html cache/网址和网站的区别

JSON的定义&#xff1a; 一种轻量级的数据交换格式&#xff0c;具有良好的可读和便于快速编写的特性。业内主流技术为其提供了完整的解决方案&#xff08;有点类似于正则表达式&#xff0c;获得了当今大部分语言的支持&#xff09;&#xff0c;从而可以在不同平台间进行数据交换…...