2024年Leetcode面T17(1-10)树,69个经典安卓面试题和答案详解

最后

简历首选内推方式,速度快,效率高啊!然后可以在拉钩,boss,脉脉,大街上看看。简历上写道熟悉什么技术就一定要去熟悉它,不然被问到不会很尴尬!做过什么项目,即使项目体量不大,但也一定要熟悉实现原理!不是你负责的部分,也可以看看同事是怎么实现的,换你来做你会怎么做?做过什么,会什么是广度问题,取决于项目内容。但做过什么,达到怎样一个境界,这是深度问题,和个人学习能力和解决问题的态度有关了。大公司看深度,小公司看广度。大公司面试你会的,小公司面试他们用到的你会不会,也就是岗位匹配度。

面试过程一定要有礼貌!即使你觉得面试官不尊重你,经常打断你的讲解,或者你觉得他不如你,问的问题缺乏专业水平,你也一定要尊重他,谁叫现在是他选择你,等你拿到offer后就是你选择他了。

另外,描述问题一定要慢!不要一下子讲一大堆,慢显得你沉稳、自信,而且你还有时间反应思路接下来怎么讲更好。现在开发过多依赖ide,所以会有个弊端,当我们在面试讲解很容易不知道某个方法怎么读,这是一个硬伤…所以一定要对常见的关键性的类名、方法名、关键字读准,有些面试官不耐烦会说“你到底说的是哪个?”这时我们会容易乱了阵脚。正确的发音+沉稳的描述+好听的嗓音决对是一个加分项!

最重要的是心态!心态!心态!重要事情说三遍!面试时间很短,在短时间内对方要摸清你的底子还是比较不现实的,所以,有时也是看眼缘,这还是个看脸的时代。

希望大家都能找到合适自己满意的工作!

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

示例 1:

输入:[3,0,1]

输出:2

示例 2:

输入:[9,6,4,2,3,5,7,0,1]

输出:8

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/missing-number-lcci

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

先求0-n和,最后减去sum(nums)

class Solution {

public int missingNumber(int[] nums) {

int sum = 0;

for (int i = 0; i < nums.length; i++) sum += nums[i];

return nums.length * (nums.length + 1) / 2 - sum;

}

}

Q17.5 字母与数字

给定一个放有字符和数字的数组,找到最长的子数组,且包含的字符和数字的个数相同。

返回该子数组,若存在多个最长子数组,返回左端点最小的。若不存在这样的数组,返回一个空数组。

示例 1:

输入: [“A”,“1”,“B”,“C”,“D”,“2”,“3”,“4”,“E”,“5”,“F”,“G”,“6”,“7”,“H”,“I”,“J”,“K”,“L”,“M”]

输出: [“A”,“1”,“B”,“C”,“D”,“2”,“3”,“4”,“E”,“5”,“F”,“G”,“6”,“7”]

示例 2:

输入: [“A”,“A”]

输出: []

提示:

array.length <= 100000

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/find-longest-subarray-lcci

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

public String[] findLongestSubarray(String[] array) {

int start = 0;

int end = 0;

HashMap<Integer, Integer> leftIndexMap = new HashMap<>();

int preSum = 0;

leftIndexMap.put(0, -1);

for (int i = 0; i < array.length; i++) {

preSum += Character.isDigit(array[i].charAt(0)) ? 1 : -1;

if (!leftIndexMap.containsKey(preSum)) {

leftIndexMap.put(preSum, i);

} else {

int leftIndex = leftIndexMap.get(preSum);

if (i - leftIndex > end - start) {

start = leftIndex;

end = i;

}

}

}

return Arrays.copyOfRange(array, start + 1, end + 1);

}

Q17.6 2出现的次数

编写一个方法,计算从 0 到 n (含 n) 中数字 2 出现的次数。

示例:

输入: 25

输出: 9

解释: (2, 12, 20, 21, 22, 23, 24, 25)(注意 22 应该算作两次)

提示:

n <= 10^9

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/number-of-2s-in-range-lcci

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {

public int numberOf2sInRange(int n) {

int ans=0;

for(long i=1;i<=n;i*=10){

int temp=(int) (n/i);

int cur=temp%10;

int temp1=temp/10;

int temp2=(int) (n%i);

ans+=(int) (temp1*i);

if(cur==2) ans+=temp2+1;

if(cur>2) ans+=i;

}

return ans;

}

}

Q17.7 婴儿名字

每年,政府都会公布一万个最常见的婴儿名字和它们出现的频率,也就是同名婴儿的数量。有些名字有多种拼法,例如,John 和 Jon 本质上是相同的名字,但被当成了两个名字公布出来。给定两个列表,一个是名字及对应的频率,另一个是本质相同的名字对。设计一个算法打印出每个真实名字的实际频率。注意,如果 John 和 Jon 是相同的,并且 Jon 和 Johnny 相同,则 John 与 Johnny 也相同,即它们有传递和对称性。

在结果列表中,选择字典序最小的名字作为真实名字。

示例:

输入:names = [“John(15)”,“Jon(12)”,“Chris(13)”,“Kris(4)”,“Christopher(19)”], synonyms = [“(Jon,John)”,“(John,Johnny)”,“(Chris,Kris)”,“(Chris,Christopher)”]

输出:[“John(27)”,“Chris(36)”]

提示:

names.length <= 100000

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/baby-names-lcci

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {

public String[] trulyMostPopular(String[] names, String[] synonyms) {

Map<String, Integer> map = new HashMap<>();

Map<String, String> unionMap = new HashMap<>();

for (String name : names) { //统计频率

int idx1 = name.indexOf(‘(’);

int idx2 = name.indexOf(‘)’);

int frequency = Integer.valueOf(name.substring(idx1 + 1, idx2));

map.put(name.substring(0, idx1), frequency);

}

for (String pair : synonyms) { //union同义词

int idx = pair.indexOf(‘,’);

String name1 = pair.substring(1, idx);

String name2 = pair.substring(idx + 1, pair.length() - 1);

while (unionMap.containsKey(name1)) { //找name1祖宗

name1 = unionMap.get(name1);

}

while (unionMap.containsKey(name2)) { //找name2祖宗

name2 = unionMap.get(name2);

}

if(!name1.equals(name2)){ //祖宗不同,要合并

int frequency = map.getOrDefault(name1, 0) + map.getOrDefault(name2, 0); //出现次数是两者之和

String trulyName = name1.compareTo(name2) < 0 ? name1 : name2;

String nickName = name1.compareTo(name2) < 0 ? name2 : name1;

unionMap.put(nickName, trulyName); //小名作为大名的分支,即大名是小名的祖宗

map.remove(nickName); //更新一下数据

map.put(trulyName, frequency);

}

}

String[] res = new String[map.size()];

int index = 0;

for (String name : map.keySet()) {

StringBuilder sb = new StringBuilder(name);

sb.append(‘(’);

sb.append(map.get(name));

sb.append(‘)’);

res[index++] = sb.toString();

}

return res;

}

}

Q17.8 马戏团人塔

有个马戏团正在设计叠罗汉的表演节目,一个人要站在另一人的肩膀上。出于实际和美观的考虑,在上面的人要比下面的人矮一点且轻一点。已知马戏团每个人的身高和体重,请编写代码计算叠罗汉最多能叠几个人。

示例:

输入:height = [65,70,56,75,60,68] weight = [100,150,90,190,95,110]

输出:6

解释:从上往下数,叠罗汉最多能叠 6 层:(56,90), (60,95), (65,100), (68,110), (70,150), (75,190)

提示:

height.length == weight.length <= 10000

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/circus-tower-lcci

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {

public int bestSeqAtIndex(int[] height, int[] weight) {

int len = height.length;

int[][] person = new int[len][2];

for (int i = 0; i < len; ++i)

person[i] = new int[]{height[i], weight[i]};

Arrays.sort(person, (a, b) -> a[0] == b[0] ? b[1] - a[1] : a[0] - b[0]);

int[] dp = new int[len];

int res = 0;

for (int[] pair : person) {

int i = Arrays.binarySearch(dp, 0, res, pair[1]);

if (i < 0)

i = -(i + 1);

dp[i] = pair[1];

if (i == res)

++res;

}

return res;

}

}

Q17.9 第 k 个数

最后

写到这里也结束了,在文章最后放上一个小小的福利,以下为小编自己在学习过程中整理出的一个学习思路及方向,从事互联网开发,最主要的是要学好技术,而学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯,更加需要准确的学习方向达到有效的学习效果。

image

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Q17.9 第 k 个数

最后

写到这里也结束了,在文章最后放上一个小小的福利,以下为小编自己在学习过程中整理出的一个学习思路及方向,从事互联网开发,最主要的是要学好技术,而学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯,更加需要准确的学习方向达到有效的学习效果。

[外链图片转存中…(img-KyVUbPVs-1714983630396)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值