java版排序算法之选择,冒泡,折半

java版排序算法之选择,冒泡,折半

class ArrDemo5{
	public static void main(String[] args){
		
		int[] arr = {4,34,56,65,78,87,98,100};
		//int index = getIndex(arr, 56);
		//System.out.println(index);
		//bubbleSort(arr);
		//selectSort(arr);
		int index = halfSearch(arr, 77);
		System.out.println(index);
		
		
	}
	
	
	//二分查找法,折半查找法
	public static int halfSearch(int[] arr, int key){
		int min = 0;//记录数组起始下标
		int max = arr.length-1;//记录数组最后下标
		int mid = (min+max)/2;//计算中间下标
		while(key != arr[mid]){
			if(key > arr[mid]){
				min = mid + 1;
			}
			if(key < arr[mid]){
				max = mid - 1;
			}
			if(min > max){
				return -1;
			}
			//重新计算中间下标
			mid = (min + max)/2;
		}
		return mid;
	}
	
	
	//一般查找
	public static int getIndex(int[] arr, int key){
		for(int i=0; i<arr.length; i++){
			if(key == arr[i]){
				return i;
			}
		}
		return -1;
	}
	
	//选择排序
	public static void selectSort(int[] arr){
		for(int i=0; i<arr.length-1; i++){
			for(int j=i+1; j<arr.length; j++){
				if(arr[i] > arr[j]){
					//int temp = arr[j];
					//arr[j] = arr[i];
					//arr[i] = temp;
					swap(arr, i, j);
					
				}
			}
		}
		printArr(arr);
	}
	
	//冒泡排序
	public static void bubbleSort(int[] arr){
		for(int i=arr.length-1;i>0; i--){
		   for(int j=0; j<i; j++){
				if(arr[j] > arr[j+1]){
					//int temp = arr[j+1];
					//arr[j+1] = arr[j];
					//arr[j] = temp;
					swap(arr, i, j);
				}
			}
		}
		printArr(arr);
	}
	
	//打印数组
	public static void printArr(int[] arr){
		for(int i=0; i<arr.length; i++){
			System.out.println(arr[i]);
		}
	}
	
	//交换数组中两个位置
	public static void swap(int[] arr, int from, int to){
		int temp = arr[from];
		arr[from] = arr[to];
		arr[to] = temp;
	}
}

 

 

 

冒泡排序


//冒泡排序

class asd{
	public static void main(String[] args){
		int[] arr = { 3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48 };	
		// 统计比较次数
		int count = 0;
		// 第一轮比较
		for (int i = 0; i < arr.length - 1; i++) {
		// 第二轮比较
		for (int j = 0; j < arr.length - 1 - i; j++) {
			if (arr[j] > arr[j + 1]) {
				// 交换位置
				int temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
			}
			count++;
		}
		System.out.println(count);
		}
		for(int i = 0;i < arr.length-1;i++)
		{
			System.out.print(arr[i]+" ");
		}
	}

}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114848.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 详解单调队列算法

    详解单调队列算法前言如果你对这篇文章可感兴趣,可以点击「【访客必读-指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。在上一篇文章中,我们介绍了「单调栈」这一最常考察的线性数据结构。而今天我们将继续沿着这个思路,介绍另一个与其“齐名”的线性数据结构,即「单调队列」。「单调队列」在「数据结构」题中的分布较为广泛,且常被当作优化「动态规划」的一种重要手段,因此该算法在面试中考察的频率较高,属于必知必会的知识点。队列首先我们来回忆一下「队列」。「队列」是一种「先进先出」的线性数据结构,其中元素

    2022年6月25日
    21
  • java messagedigest,在C#中的Java MessageDigest类[通俗易懂]

    java messagedigest,在C#中的Java MessageDigest类[通俗易懂]IrequireacertainpieceofencrytionlogicdoneinJavatobeconvertedinC#thejavacodesnippetisasfollows.WhatwouldbetheC#equivalentfortheupdate(),Digestandresetfunctions?解决方案In…

    2022年7月16日
    22
  • java8两个List集合取交集、并集、差集、去重并集

    java8两个List集合取交集、并集、差集、去重并集、、、importjava.util.ArrayList;importjava.util.List;importstaticjava.util.stream.Collectors.toList;publicclassTest{publicstaticvoidmain(String[]args){List<String>list1=new…

    2022年9月1日
    4
  • 最小二乘法原理及应用

    最小二乘法原理及应用最小二乘法是一种在误差估计 不确定度 系统辨识及预测 预报等数据处理诸多学科领域得到广泛应用的数学工具

    2025年8月1日
    1
  • oracle数据库怎么创建连接_eclipse连接数据库代码

    oracle数据库怎么创建连接_eclipse连接数据库代码应用场景:目标数据分散在多个实例下的时候,需要把这些需要的数据整合到同一个数据库下,需要创建数据库连接。用语句创建参考文章:https://blog.csdn.net/hongweibing1/article/details/50623669但是报错:“口令缺失或无效”,选择手动创建。1、找到DatabaseLinks,右键选择“新建”2、进入“创建数据库连接”窗口,勾选“公共”,填写“数据库连接-名称”、“连接到-用户名”、“连接到-口令”、“连接到-数据库”。3、点击左下方的“应用”即

    2022年9月22日
    2
  • ElasticSearch join连接查询「建议收藏」

    ElasticSearch join连接查询「建议收藏」ElasticSearchjoin连接查询特别说明:文章所有内容基于ElasticSerch5.5.3版本ElasticSerch的连接查询有两种方式实现nestedparent和child关联查询nested存储结构nested的方式和其他字段一样,在同一个type里面存储,以数组的方式存储在type里,格式如下:PUTindex…

    2022年6月16日
    78

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号