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

Java:简单算法:冒泡排序、选择排序、二分查找

冒泡排序

在这里插入图片描述

// 1、准备一个数组
int[] arr = {5231};//2、定义一个循环控制排几轮
for (int i = 0; i < arr.length - 1; i++) {
// i = 0 1 2        【5,2,3,1】      次数
// i = 0 第一轮       0  1  2            3
// i = 1 第二轮       1  2               2
// i = 2 第三轮       0                  1//3、定义一个循环控制每轮比较几次。
for (int j = 0; i < arr.length-i-1; j++) {
//判断当前位置的元素值,是否大于后一个位置处的元素值,如果大则交换。
if(arr[j] > arr[j+1]){
int temp = arr[i+1];
arr[j+1] = arr[i];
arr[j] = temp;}}
}
system.out.println(Arrays.toString(arr));

选择排序

// 1、准备一个数组
int[] arr = {5231};//2、定义一个循环控制排几轮
for (int i = 0; i < arr.length - 1; i++) {
// i = 0 1 2        【5,2,3,1】      
//                    0 1  2  3
// i = 0 第一轮     j=   1  2  3          
// i = 1 第二轮     j=      2  3               
// i = 2 第三轮     j=         3                  //3、定义一个循环控制每轮比较几次。
for (int j = i + 1; i < arr.length; j++) {
//判断当前位置的元素值,是否大于后一个位置处的元素值,如果大则交换。
if(arr[i] > arr[j]){
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;}}
}
system.out.println(Arrays.toString(arr));

简化代码,适用于当数组非常大时提高性能

// 1、准备好一个数组
int[] arr = {5132};/ ///2、控制选择几轮
for (int i = 0; i < arr.length - 1; i++) {int minIndex = i;//3、控制每轮选择几次。
for (int j = i + 1; j < arr.length; j++) {
//判断当前位置是否大于后面位置处的元素值,若大于则交换。
if(arr[minIndex] > arr[i]){
minIndex = j;}
}
//决定是否交换。
if(i != minIndex) {
int temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;}
}
system.out.println(Arrays.toString(arr));

二分查找

  public static void main(String[] args) {//1.准备好一个数组,首先这个数组必须是排好顺序的int[] arr = {7,23,79,81,103,127,131,147};//接下来将二分法定义成一个方法,调用这个方法System.out.println(binarySearch(arr, 81));//返回 3 System.out.println(binarySearch(arr, 166));//返回 -1}public static int binarySearch(int[] arr, int data){//1.定义两个变量,一个站在左边位置,一个站在右边位置。int left = 0;int right = arr.length-1;//2.定义一个循环 控制折半while (left <= right){//3.每次折半都算出中间位置的索引int middle = (left + right)/2;//4.判断当前要找的元素值,与中间位置处的元素值的大小情况if (data < arr[middle]) {//往左边找,截止位置(右边位置) = 中间位置 - 1;right = middle -1;}else if (data >arr[middle]){//往右边找,截止位置(左边位置) = 中间位置 + 1;left = middle +1;}else {return middle;//刚好中间位置就是需要的元素}}return -1;//代表数组中没有要找的元素。}
http://www.lryc.cn/news/123931.html

相关文章:

  • C、C++项目中 configure、makefile.am、makefile.in、makefile 之间的关系
  • 【网络】传输层——UDP | TCP(协议格式确认应答超时重传连接管理)
  • 198.打家劫舍 ● 213.打家劫舍II ● 337.打家劫舍III
  • ArcGIS Maps SDK for JavaScript系列之一:在Vue3中加载ArcGIS地图
  • 服务器扩展未生效
  • Jenkins构建自由风格项目发布jar到服务器
  • Rabbitmq延迟消息
  • miniExcel 生成excel
  • Handler详解
  • Feign忽略Https的SSL最佳方案(且保证负载均衡将失效)
  • Neo4j之SET基础
  • Redis 缓存过期及删除
  • 万字长文·通俗易懂·一篇包掌握——输入/输出·文件操作(c语言超详细系列)(二)
  • 【左神算法刷题班】第17节:在有序二维数组中查找目标值、等于目标字符串的子序列个数
  • 【Terraform学习】本地变量(Terraform配置语言学习)
  • zabbix自动注册服务器以及部署代理服务器
  • 掌握Python的X篇_32_使用python编辑pdf文件_pdfrw
  • 【软件工程】软件测试
  • Android性能优化——内存优化
  • Android Studio实现图形验证码
  • JAVA面试数据库篇
  • Android高手进阶教程(三)之----Android 中自定义View的应用.
  • 第一百一十三回 dart中的getter/setter方法
  • 搭建Docker环境
  • 微服务08-多级缓存
  • Intel汇编和ATT汇编的区别?
  • MongoDB 备份与恢复
  • 探讨uniapp的网络通信问题
  • 【左神算法刷题班】第18节:汉诺塔问题、岛屿问题、最大路径和问题
  • 网络安全体系架构介绍