Leetcode面T10(1-9)数组,成功从小公司跳槽

本文介绍了三个算法问题:1) 字符串组的字母异位词分组,通过排序字符串实现高效分组;2) 搜索旋转数组,直接搜索或采用二分查找优化;3) 在稀疏数组中查找字符串,利用二分搜索提高效率。这些方法在实际编程中有着广泛的应用,有助于提升算法思维和代码质量。
摘要由CSDN通过智能技术生成

输入: [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”],

输出:

[

[“ate”,“eat”,“tea”],

[“nat”,“tan”],

[“bat”]

]

说明:

所有输入均为小写字母。

不考虑答案输出的顺序。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/group-anagrams-lcci

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

public class Solution {

public List<List> groupAnagrams(String[] strs) {

if(strsnull||strs.length0) return null;

HashMap<String,List> map = new HashMap<>();

//遍历所有字符串

for (String str : strs) {

char[] chars = str.toCharArray();

//对每一个字符串进行排序,乱序后再排序后的字符串肯定都是一样的,直接用这个作为Key存入map中

Arrays.sort(chars);

String key = new String(chars);

List list = null;

//取key对应的value

if(!map.containsKey(key)) {

list = new ArrayList<>();

}else {

list = map.get(key);

}

list.add(str);

map.put(key,list);

}

return new ArrayList<>(map.values());

}

}

Q10.3 搜索旋转数组

搜索旋转数组。给定一个排序后的数组,包含n个整数,但这个数组已被旋转过很多次了,次数不详。请编写代码找出数组中的某个元素,假设数组元素原先是按升序排列的。若有多个相同元素,返回索引值最小的一个。

示例1:

输入: arr = [15, 16, 19, 20, 25, 1, 3, 4, 5, 7, 10, 14], target = 5

输出: 8(元素5在该数组中的索引)

示例2:

输入:arr = [15, 16, 19, 20, 25, 1, 3, 4, 5, 7, 10, 14], target = 11

输出:-1 (没有找到)

提示:

arr 长度范围在[1, 1000000]之间

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/search-rotate-array-lcci

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

class Solution {

public int search(int[] arr, int target) {

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

if (arr[i]==target){

return i;

}

}

return -1;

}

}

Q10.5 稀疏数组搜索

稀疏数组搜索。有个排好序的字符串数组,其中散布着一些空字符串,编写一种方法,找出给定字符串的位置。

示例1:

输入: words = [“at”, “”, “”, “”, “ball”, “”, “”, “car”, “”, “”,“dad”, “”, “”], s = “ta”

输出:-1

说明: 不存在返回-1。

示例2:

输入:words = [“at”, “”, “”, “”, “ball”, “”, “”, “car”, “”, “”,“dad”, “”, “”], s = “ball”

输出:4

提示:

words的长度在[1, 1000000]之间

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/sparse-array-search-lcci

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

在Java中判断字符串值是否相等用s1,equals(s1)。不要直接用==,被耗了好长时间mmp.

class Solution {

//直接法

// public int findString(String[] words, String s) {

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

// if(words[i].equals(s)){

// return i;

// }

// }

// return -1;

// }

//二分搜索法

public int findString(String[] words, String s) {

//直接二分搜索

int left = 0;

int right = words.length - 1;

//[left.right)

while(left <= right){

while(left < words.length && words[left].equals("")){

left++;

}

while(right >= 0 && words[right].equals("")){

right–;

}

int mid = left + (right - left) / 2;

while(mid < words.length && words[mid].equals("")){

mid++;

}

if(words[mid].equals(s)){

return mid;

}else if(words[mid].compareTo(s) > 0){

//收缩右边界,锁定左边界

right = mid - 1;

}else if(words[mid].compareTo(s) < 0){

//收缩左边界,锁定右边界

left = mid + 1;

}

}

return -1;

}

}

Q10.9 排序矩阵查找

给定M×N矩阵,每一行、每一列都按升序排列,请编写代码找出某元素。

示例:

现有矩阵 matrix 如下:

[

[1,   4,  7, 11, 15],

[2,   5,  8, 12, 19],

[3,   6,  9, 16, 22],

[10, 13, 14, 17, 24],

[18, 21, 23, 26, 30]

]

给定 target = 5,返回 true。

给定 target = 20,返回 false。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/sorted-matrix-search-lcci

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

class Solution {

public boolean searchMatrix(int[][] matrix, int target) {

if (matrix == null || matrix.length == 0) {

总结

最后对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

上述【高清技术脑图】以及【配套的架构技术PDF】可以关注我免费获取

Android学习PDF+架构视频+面试文档+源码笔记

外链图片转存中…(img-T7yObjLl-1646396873683)]

[外链图片转存中…(img-5S1BKBMn-1646396873684)]

上述【高清技术脑图】以及【配套的架构技术PDF】可以关注我免费获取

Android学习PDF+架构视频+面试文档+源码笔记

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值