Day05 学习java(排序、查找)

排序

所谓排序,就是指让保存的元素按照一定的规则进行排序存储,比如升序降序等。

1.冒泡排序:

思想:以升序为例,从后往前(或从前往后)两两比较相邻元素的值,若为逆序(即A[i-1]>A[i]),则交换他们,直到序列比较完。称这样过程为"一趟"冒泡排序,第一趟排序使关键字值最小的一个元素"冒"到最前面(如果值相同不交换,为了保证稳定性)
空间复杂度:O(1)
最好情况下的时间复杂度(已经排好序):O(n)
最坏情况下的时间复杂度(完全逆序):O(n^2)
平均时间复杂度为:O(n^2)



	public static void main(String[] args) {
		int[] a = { 9,8,7,6,5,4,3,2,1 };
		sort(a);
		for (int i = 0; i < a.length; i++) {
			System.out.print(a[i] + " ");
		}
	}

	public static void sort(int[] arr) {
		// 中间变量
		int temp;

		for (int i = 0; i < arr.length - 1; i++) {

			// n个元素比较n-1次
			for (int j = 0; j < arr.length - 1 - i; j++) {
				// 不排序已经完成排序的i个元素
				if (arr[j] > arr[j + 1]) {
					// 如果前一个元素大于后一个元素则交换,把最大的冒泡到最后
					temp = arr[j];
					arr[j] = arr[j + 1];
					arr[j + 1] = temp;
				}
			}
		}
	}


在这里插入图片描述

2.选择排序:

思想:以升序为例,每次把最小的放到左边。先拿出第一个,假设是最小的,然后依次和后面的比较,如果有比第一个小的则交换下标,比较一轮之后已经得到了最小元素的下标,然后和最前面的元素交换即可。重复执行多次直到元素后面没有其他元素
空间复杂度:O(1)
最好情况下的时间复杂度(已经排好序):O(n^2)
最坏情况下的时间复杂度(完全逆序):O(n^2)
平均时间复杂度为:O(n^2)

	public static void main(String[] args) {
		int[] a = { 9, 8, 7, 22, 6, 5, 4, 10, 3, 2, 1, 11 };
		sort(a);
		for (int i = 0; i < a.length; i++) {
			System.out.print(a[i] + "  ");
		}
	}

	public static void sort(int[] arr) {
		// 中间变量
		int temp;
		// n个元素比较n-1次
		for (int i = 0; i < arr.length - 1; i++) {
			int min = i;
			// 不比较已经排好序的i个元素
			for (int j = 1 + i; j < arr.length; j++) {
				// 如果后面的元素小于位置i的元素,则记录下标到min
				min = arr[min] > arr[j] ? j : min;
			}
			// 如果min不等于i,则说明min位置的元素比i位置的元素小,交换
			if (min != i) {
				temp = arr[i];
				arr[i] = arr[min];
				arr[min] = temp;
			}
		}
	}

在这里插入图片描述

查找元素

1.顺序查找:

就是用所有数据挨个和目标数据比较,目标数据靠前的话相对快一些

public static void main(String[] args) {
		int[] a = { 1, 2, 3, 7, 8, 9, 4, 5, 6 };
		int num = 8;
		int result = search(a, num);
		System.out.println("在第 " + result + " 位");
	}

	public static int search(int[] arr, int target) {
		// 遍历数组,挨个与目标值target比较
		for (int i = 0; i < arr.length; i++) {
			if (arr[i] == target)
				// 找到则返回下标
				return i;
		}
		// 没找到则返回-1
		return -1;
	}

在这里插入图片描述

2.二分查找:

又称为折半查找要求数据必须有序,一般用于固定数据,因为有序,所以添加和删除比较麻烦。
每次比较中间值与目标值,一次比较会筛去1/2的元素

		public static void main(String[] args) {
		int[] a = { 1, 7, 8, 15, 19, 21, 55, 245, 1000 };
		int num = 55;
		int result = binarySearch(a, num);
		System.out.println("在第 " + result + " 位");
	}

	public static int binarySearch(int[] arr, int target) {
		int low = 0, high = arr.length - 1, mid = (low + high) / 2;
		while (low <= high) {
			if (arr[mid] == target) {
				// mid位置元素值和target相等时返回mid
				return mid;
			} else if(target>arr[mid]{
				// target比mid位置元素值大,则low指向mid右边一位
				low = mid + 1 ;
			}else {
				// target比mid位置元素值小,则high指向mid左边一位
				high = mid -1;
			}
			// 更新mid值
			mid = (low + high) / 2;
		}
		// 未找到返回-1
		return -1;
	}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值