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)
上一篇 2021年9月29日 上午7:00
下一篇 2021年9月29日 上午8:00


相关推荐

  • vscode 前端常用插件推荐「建议收藏」

    1.vscode简介vscode是微软开发的的一款代码编辑器,就如官网上说的一样,vscode重新定义(redefined)了代码编辑器。 当前市面上常用的轻型代码编辑器主要是:sublime,notepad++,editplus,atom这几种。 比起notepad++、editplus,vscode集成了许多IDE才具有的功能,比起它们更像一个代码编辑器; 比起sublime,…

    2022年4月7日
    61
  • STM32CubeMX学习笔记(26)——SDIO接口使用(读写SD卡)

    STM32CubeMX学习笔记(26)——SDIO接口使用(读写SD卡)一、SDIO简介SD卡(SecureDigitalMemoryCard)在我们生活中已经非常普遍了,控制器对SD卡进行读写通信操作一般有两种通信接口可选,一种是SPI接口,另外一种就是SDIO接口。SDIO全称是安全数字输入/输出接口,多媒体卡(MMC)、SD卡、SDI/O卡都有SDIO接口。MMC卡可以说是SD卡的前身,现阶段已经用得很少。STM32F10x系列控制器有一个SDIO主机接口,它可以与MMC卡、SD卡、SDI/O卡以及CE-A

    2022年10月3日
    7
  • 怎么修改Ubuntu更新源服务器为国内地址

    怎么修改Ubuntu更新源服务器为国内地址 Ubuntu系统安装完默认更新源是国外服务器,总所周知的原因我天朝连接外国的速度那是很有讲究的,如果偶尔用用Ubuntu也就无所谓了,但是经常使用肯定会让你崩溃的,国内国外速度相差十倍都不止。更新源地址也很简单,有两种方法,一种是如果安装了图形界面,通过配置中心来更改是很方便的;还有一种就是纯服务器版,没有图形界面通过更改配置文件来更换源地址,并且命令行的方法可以随意添加任何可用的更新源地址,…

    2022年5月14日
    52
  • MQTT服务器部署

    MQTT服务器部署MQTT服务器部署现在物联网常用的通信方式有哪些?RF433/315M、蓝牙、Zigbee、wifi、以太网等等,通信协议也按不同功能分了许多种,例如TCP、MQTT等,具体可到https://blog.csdn.net/sinat_36098122/article/details/80930168研究。我当前用的比较多的是MQTT协议,它被较多的用来需要省电的设备通信上,采用发布/订阅的形式…

    2022年5月8日
    82
  • 【保姆级教程】OpenClaw 零基础部署与精选Skills安装指南,含阿里云百炼配置与常见问题解答

    【保姆级教程】OpenClaw 零基础部署与精选Skills安装指南,含阿里云百炼配置与常见问题解答

    2026年3月15日
    3
  • AI “养龙虾”火了!上市公司扎堆回应

    AI “养龙虾”火了!上市公司扎堆回应

    2026年3月13日
    2

发表回复

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

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