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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • php layer弹出层更改背景,详解Layer弹出层样式[通俗易懂]

    php layer弹出层更改背景,详解Layer弹出层样式[通俗易懂]前言:学习layer弹出框,之前项目是用bootstrap模态框,后来改用layer弹出框,在文章的后面,我会分享项目的一些代码(我自己写的)。layer至今仍作为layui的代表作,她的受众广泛并非偶然,而是这五年多的坚持,不断完善和维护、不断建设和提升社区服务,使得猿们纷纷自发传播,乃至于成为今天的Layui最强劲的源动力。目前,layer已成为国内最多人使用的web弹层组件,GitHub自然…

    2022年7月13日
    14
  • 自动化测试系列(三)|UI测试「建议收藏」

    自动化测试系列(三)|UI测试「建议收藏」UI测试是一种测试类型,也称为用户界面测试,通过该测试,我们检查应用程序的界面是否工作正常或是否存在任何妨碍用户行为且不符合书面规格的BUG。了解用户将如何在用户和网站之间进行交互以执行UI测试至关重要,通过执行UI测试,测试人员将尝试模仿用户的行为,以查看用户将如何与程序进行交互,并查看网站的运行情况是否如预期的那样,是否有缺陷。在上次的自动化测试系列(二)中为大家大体介绍了API测试的概念及在猪齿鱼中的实践展开,本文主要围绕UI测试进行概念介绍及Choerodon中的实践展开。下面.

    2025年7月21日
    0
  • linux安装weget命令,linux安装wget命令

    linux安装weget命令,linux安装wget命令wget命令是linux系统下的一个常用命令。下面由学习啦小编为大家整理了linux安装wget命令的相关知识,希望大家喜欢!linux安装wget命令方法一debian或者ubuntu:sudoapt-getinstallwgetcentos:sudoyum-yinstallwgetlinux安装wget命令方法二我们先安装linux系统比如centos7.1里面有的就…

    2022年10月16日
    0
  • AVProVideo视频进度条

    AVProVideo视频进度条1,新建slider并添加事件

    2022年7月3日
    20
  • 机器学习_正规方程(最小二乘法)的推导

    机器学习_正规方程(最小二乘法)的推导机器学习中正规方程的推导,一共两种推导方式

    2022年5月17日
    26
  • java标识符可以$开头吗_JAVA标识符

    java标识符可以$开头吗_JAVA标识符JAVA标识符JAVA标识符简介Java语言中,对于变量,常量,函数,语句块也有名字,我们统统称之为Java标识符。也就是程序员在定义java程序时,自定义的一些名字,例如helloworld程序里关键字class后跟的Demo,就是我们定义的类名。类名就属于标识符的一种。标识符除了应用在类名上,还可以用在变量、函数名、包名上。(要求同学们先记住,以后会详细见到这些)。标识符命名规则1.标识符由…

    2022年7月26日
    14

发表回复

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

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