基础算法(二)

        上一篇:基础算法(一)

        1. 冒泡排序(BubbleSort)

        原理:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后。在第二趟:仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到倒数第二个数(倒数第一的位置上已经是最大的),第二趟结束,在倒数第二的位置上得到一个新的最大数(其实在整个数列中是第二大的数)。如此下去,重复以上过程,直至最终完成排序。   由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。   用二重循环实现,外循环变量设为i,内循环变量设为j。外循环重复9次,内循环依次重复9,8,...,1次。每次进行比较的两个元素都是与内循环j有关的,它们可以分别用a[j]和a[j+1]标识,i的值依次为1,2,...,9,对于每一个i,j的值依次为1,2,...10-i。

        实现的代码如下:

public static void bubbleSort(int[] array) {
		for(int i = 1; i < array.length; i++) {
			for(int j = 0; j < array.length - i; j++) {
				if(array[j] > array[j + 1]) {
					int tmp = array[j + 1];
					array[j + 1] = array[j];
					array[j] = tmp;
				}
			}
		}
}

2. 选择排序

        原理:n个数的直接选择排序可经过n-1趟直接选择排序得到有序结果:         ①初始状态:无序区为R[1..n],有序区为空。         ②第1趟排序,在无序区R[1..n]中选出关键字最小的记录R[k],将它与无序区的第1个记录R[1]交换,使R[1..1]和R[2..n]分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。         ……         ③第i趟排序,第i趟排序开始时,当前有序区和无序区分别为R[1..i-1]和R(i..n)。该趟排序从当前无序区中选出关键字最小的记录R[k],将它与无序区的第1个记录R交换,使R[1..i]和R分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。         这样,n个数的直接选择排序可经过n-1趟直接选择排序得到有序结果。

        实现的代码如下:

public static void selectionSort(int[] array) {
		for(int i = 0; i < array.length - 1; i++) {
			int min = i;
			for(int j = i + 1; j < array.length; j++) {
				if(array[j] < array[min]) {
					min = j;
				}
			}
			if(min != i) {
				int temp = array[min];
				array[min] = array[i];
				array[i] = temp;
			}
		}
}

3. 寻找孤立数字         需求:给定一个数组,数组内的数两两相同,只有一个数是孤立的,用最快的方式找出这个数。

        分析:循环数组,判断第i个元素的值和其它位置的值是否相等,如果不存在相等的,那么这个数就是孤立数据。

        实现的代码如下:        

int[] array = {1, 2, 3, 2, 3, 1, 4};
int single = 0;
for(int i = 0; i < array.length; i++) {
  boolean isSingle = true;
  for(int j = 0; j < array.length; j++) {
    if(j != i && array[i] == array[j]) {
      isSingle = false;
      break;
    }
  }
  if(isSingle) {
    single = array[i];
    break;
  }
}

        显然这样的嵌套循环判断复杂度是很高的,所以使用^,则实现的代码如下:

int[] array = {1, 2, 3, 2, 3, 1, 4};
int single = array[0];
for(int i = 1; i < array.length; i++) {
		single ^= array[i];
}

        一个for循环搞定,不怕做不到,就怕想不到。

4. 进制转换

        将一个整型数据转换成二进制字符串。

        分析:整型一共32位,最高位代表正负,那么得到第i位的数只需要将整数右移i-1位,实现的代码如下;

public static String toBinary(int value) {
		StringBuilder build = new StringBuilder();
		for(int i = 31; i >= 0; i--) {
			build.append(value >> i & 1);// 和1做与操作之后,该位置之前的数全部干掉
		}
		return build.toString();	
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏行者常至

golang string、int、int64 float 互相转换

963
来自专栏King_3的技术专栏

完全多部图的判断(个人思考)

给定一张包含N个点、M条边的无向图,每条边连接两个不同的点,且任意两点间最多只有一条边。对于这样的简单无向图,如果能将所有点划分成若干个集合,使得任意两个同一集...

1093
来自专栏开发与安全

算法:静态查找表(Static Search Table)(顺序查找、二分查找、插值查找、斐波纳契查找)

查找表(Search table)是由同一类型的数据元素(或记录)构成的集合。关键字(key)是数据元素中某个数据项的值,又称为键值,用它可以表示一个数据元素,...

2115
来自专栏大数据钻研

44 个 JavaScript 变态题解析

当初笔者做这套题的时候不仅怀疑智商, 连人生都开始怀疑了…. 不过, 对于基础知识的理解是深入编程的前提. 让我们一起来看看这些变态题到底变态不变态吧! 第1题...

3276
来自专栏菩提树下的杨过

javascript:算法笔记

入门级算法-线性查找-时间复杂度O(n)--相当于算法界中的HelloWorld //线性搜索(入门HelloWorld) //A为数组,x为要...

17310
来自专栏数据结构与算法

小米OJ刷题日志

$f[i][j]$表示第一个队列匹配到了$i$位置,第二个队列匹配到了$j$位置是否可行

2152
来自专栏算法channel

机器学习储备(8):numpy之linspace 和 logspace

1 linspace在numpy中是创建等差数列, 先看例子: A = np.linspace(1,11,11) 结果:array([ 1., 2., ...

3216
来自专栏五分钟学算法

每天一算:Odd Even Linked List

我们会在每天早上8点30分准时推送一条LeetCode上的算法题目,并给出该题目的动画解析以及参考答案,每篇文章阅读时长为五分钟左右。

763
来自专栏Coding迪斯尼

使用普拉特分析法解析极为复杂的算术表达式

803
来自专栏韦弦的微信小程序

Swift 有效的括号 - LeetCode

给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。

752

扫码关注云+社区