242.有效的字母异位词
    字符转int c-‘a’
    哈希表进行记录、消除出现的次数。

    定义一个数组叫做record用来上记录字符串s里字符出现的次数。
    需要把字符映射到数组也就是哈希表的索引下标上,因为字符a到字符z的ASCII是26个连续的数值,所以字符a映射为下标0,相应的字符z映射为下标25。
    再遍历 字符串s的时候,只需要将 s[i] - ‘a’ 所在的元素做+1 操作即可(record[s[i]=’a’]++),并不需要记住字符a的ASCII,只要求出一个相对数值就可以了。 这样就将字符串s中字符出现的次数,统计出来了。
    那看一下如何检查字符串t中是否出现了这些字符,同样在遍历字符串t的时候,对t中出现的字符映射哈希表索引上的数值再做-1的操作。
    那么最后检查一下,record数组如果有的元素不为零0,说明字符串s和t一定是谁多了字符或者谁少了字符,return false。
    最后如果record数组所有元素都为零0,说明字符串s和t是字母异位词,return true。
    时间复杂度为O(n),空间上因为定义是的一个常量大小的辅助数组,所以空间复杂度为O(1)。

    1. class Solution {
    2. public:
    3. bool isAnagram(string s, string t) {
    4. int record[26] = {0};
    5. for(char c:s)
    6. record[c-'a'] += 1;
    7. for(char c:t)
    8. record[c-'a'] -= 1;
    9. for(int i =0;i<26;i++)
    10. {
    11. if(record[i]!=0)
    12. return false;
    13. }
    14. return true;
    15. }
    16. };