int N = array.length;
//从1开始,因为数组的第一个数,肯定是有序的。
for (int i = 1; i < N; i++) {
int temp = array[i];
int leftIndex = i - 1;
//从右往左依次比较直到找到比他小的数
while (leftIndex >= 0 && array[leftIndex] > temp) {
array[leftIndex + 1] = array[leftIndex];
leftIndex–;
}
array[leftIndex + 1] = temp;
}
}
4.冒泡排序
假设一组无序数列 8,6,19,10,15。我们从头开始依次比较相邻的两个数,发现8比6大我们交换两个数的位置。数列变成6,8,19,10,15。我们在比较8和19,19比8大位置不动,我们在拿10根19比较,10比19小,交换位置,序列变成8,6,10,19,15,我们在拿15和19比较,15小于19,交换位置。第一轮排序结束,序列中最大的数19被排在了数列的最后。每轮排序结束剔除最后的数,重复上面的步骤,每结束一轮排序,都会在现有数列中找出最大的放在最后。直到没有任何一对数需要比较,排序完成。
Java中冒泡排序的实现:
//冒泡排序
public void bubbleSort(int[] array) {
int N = array.length;
for (int k = N - 1; k >= 0; k–) {
for (int i = 0; i < k; i++) {
if (array[i] > array[i + 1]) {
int temp = array[i];
array[i] = array[i + 1];
array[i + 1] = temp;
}
}
}
}
5.快速排序
假设有一个无序数列。快速排序是找出一个元素作为基准,然后对数列进行
分区操作,是基准左边元素的值都小于基准元素,基准元素右边的值都大于基准元素。然后在对基准元素左边的元素,和右边的元素重复上面的分区操作。直到序列不能再分区为止。
快速排序的代码实现:
public void sort(int[] a, int low, int high) {
int start = low;
int end = high;
int key = a[low];
while (end > start) {
//从后往前比较
while (end > start && a[end] >= key) {
//如果没有比关键值小的,比较下一个,直到有比关键值小的交换位置
end–;
}
int temp = a[end];
a[end] = a[start];
a[start] = temp;
//从前往后比较
while (end > start && a[start] <= key) {
//如果没有比关键值大的,比较下一个,直到有比关键值大的交换位置;
start++;
}
int temp1 = a[start];
a[start] = a[end];
a[end] = temp1;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
最后
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
【Android高级架构视频学习资源】
篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
[外链图片转存中…(img-Tsg08Qwa-1711865640469)]
【Android高级架构视频学习资源】