小山菌_代码随想录算法训练营第六天| 242.有效的字母异位词 、349. 两个数组的交集 、 202. 快乐数 、1.两数之和(第五天休息)

242.有效的字母异位词

文档讲解:代码随想录.有效的字母异位词
视频讲解:学透哈希表,数组使用有技巧!Leetcode:242.有效的字母异位词
状态:已完成

代码实现

class Solution {
public:
    bool isAnagram(string s, string t) {

        int record[26] = {0};
        for (int i = 0; i < s.size(); i++) {
            record[s[i] - 'a']++;
        }

        for (int i = 0; i < t.size(); i++) {
            record[t[i] - 'a']--;
        }

        for (int i = 0; i < 26; i++) {
            if (record[i] != 0) {
                return false;
            }
        }
        return true;
    }
};

心得记录:

  1. 常见的哈希结构包括数组,set(集合)和map(映射),即可以用数组构建哈希结构,上面这个例子就是

  2. set和map结构的理解
    在这里插入图片描述

  3. 这里红黑树和哈希表算是有个印象,后面通过做题提升记忆

  4. 使用数组来做哈希的题目,是因为题目都限制了数值的大小。

349. 两个数组的交集

文档讲解:代码随想录.两个数组的交集
视频讲解:学透哈希表,set使用有技巧!Leetcode:349. 两个数组的交集
状态:已完成

代码实现

class Solution {
public:
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {

        unordered_set<int> result_set;
        unordered_set<int> nums(nums1.begin(), nums1.end());
        for (int num : nums2) {

            if (nums.find(num) != nums.end()) {
                result_set.insert(num);
            }
        }
        return vector<int>(result_set.begin(), result_set.end());
    }
};

心得记录:

  1. 基本的查找方法不是很熟练,以及unordered_set的基本使用方法不够熟练
  2. 例子说明了这种方法应该是拉链法解决哈希冲突。

202. 快乐数

文档讲解:代码随想录.快乐数
视频讲解:无
状态:已完成

代码实现

class Solution {
public:
    int getSum(int n) {
        int sum = 0;
        while(n){
           sum +=  (n % 10) * (n % 10);
            n = n / 10;
        }
        return sum;
            
       
    }

    bool isHappy(int n) {

        unordered_set<int> set;
        while (1) {

            int sum = getSum(n);
            if(sum == 1){
                return true;
            }

            //如果出现过说明出现错误
            if(set.find(sum) != set.end()){
                return false;
            }else{
                set.insert(sum);
            }
            n= sum;
        }
    }
};

心得记录:

  1. 暂时先按照答案过了一遍

1.两数之和

文档讲解:代码随想录.两数之和
视频讲解:梦开始的地方,Leetcode:1.两数之和,学透哈希表,map使用有技巧!
状态:已完成

代码实现

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        
        std::unordered_map<int,int> map;
        for(int i = 0; i < nums.size();i++){

            auto iter= map.find(target - nums[i]);
            if(iter != map.end()){
                return {iter->second,i};
            }

            map.insert(pair<int,int>(nums[i],i));
        }
        return {};
    }
};

心得记录:

1.状态不佳, 暂时先按照答案过了一遍

在安装tensorflow2时,你收到了一个警告消息,指出你正在使用pip版本9.0.1,但是有一个新版本18.0可用。这意味着你的pip需要更新到最新版本,以便正确安装tensorflow2。你可以通过运行命令'python -m pip install --upgrade pip'来升级pip。这将安装最新版本的pip并解决冲突问题。请注意,如果你使用pip3进行软件安装,你可能会遇到这个警告消息。如果你执行了升级命令并导致pip3无法使用,你可能需要重新安装python3。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [解决错误:You are using pip version 9.0.1, however version 18.0 is available.](https://blog.csdn.net/soul778888/article/details/129340716)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [You are using pip version 9.0.1, however version 18.0 is available. You should consider upgrading vi...](https://blog.csdn.net/a562721098/article/details/119695366)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值