前言
算法的重要性不言而喻!区分度高!
现在学习的门槛低了,只有能上网每个人都可以学编程!培训班6个月就可以培养出来能干活的人,你怎么从这些人中脱颖而出?没错!就是学算法,学一些底层和基础的东西。
说的功利点是为了竞争,卷死对手。真心话说就是能提高自己的基础能力,为技术可持续发展做好充分的准备!!!
提前入门学习书籍:CPrimerPlus、大话数据结构
刷题网站
我是按照代码随想录提供的刷题顺序进行刷题的,大家也可以去刷leetcode最热200道,都可以
刷题嘛,最重要的就是坚持了!!!
画图软件
OneNote
这个要经常用,遇见不懂的流程的话就拿它画一画!
笔记软件
Typoral
题目
解析
这道题目和我们前面写的242.有效的字母异位词很像,相当于求 字符串a 和 字符串b 是否可以相互组成 ,而这道题目是求 字符串a能否组成字符串b,而不用管字符串b 能不能组成字符串a。
题目有非常重要的两个点:
- 杂志里面的字母不可重复使用。
- 说明只有小写字母,这一点很重要
暴力解法
比较容易想到对吧,两次for循环,循环的内容是判断第一个字符串的元素是否存在于第二个字符串,如果存在那么删掉第一个字符串中的元素,最后判断赎金信是否为空即可
为什么要减去a
A的ASCII码是65,字符a到字符z的ACCII是连续的数值,所以字符a - a那么对应的数字就是0,b字符呢?66-65呗,这不就和数组的索引下标对上了吗?
class Solution { public boolean canConstruct(String ransomNote, String magazine) { // 因为要存放26个英文字母,所以用数组来存储,牺牲空间提高速度 int[] record = new int[26]; // 遍历字符串出现的个数,记录到record数组中 for(char c : magazine.toCharArray()){ record[c - 'a'] += 1; } for(char c : ransomNote.toCharArray()){ record[c - 'a'] -= 1; } for(int i : record){ if(i < 0){ return false; } } return true; } }