LeetCode简单题记录

1、两数之和,给定数组nums,求和为target的两个数组元素的下标

我用了两个for循环,官方解为 哈希表,知识盲区

c 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int, int> hashtable;
        for (int i = 0; i < nums.size(); ++i) {
            auto it = hashtable.find(target - nums[i]);
            if (it != hashtable.end()) {
                return {it->second, i};
            }
            hashtable[nums[i]] = i;
        }
        return {};
    }
};

9、回文数的判断

官方解为反转一半数字,如果该数字是回文,其后半部分反转后应该与原始数字的前半部分相同;复杂度 O(log n)

我的解法:to_String() 数字转字符串 + 一个 for循环,复杂度应为 O(n)


13、罗马数字转整数

c 复制代码
map<char,int> M={
    {'I', 1}, {'V', 5}, {'X', 10}, {'L', 50},
    {'C', 100}, {'D', 500}, {'M', 1000},
};

用到 map 这个数据结构,最开始想用switch case,大概时间复杂度在O(7n),后来觉得字典可能性能高一些


相关推荐
CoderIsArt12 分钟前
生成一个立方体贴图(Cube Map)
算法·sharpgl
且听风吟ayan18 分钟前
leetcode day20 滑动窗口209+904
算法·leetcode·c#
m0_6759882318 分钟前
Leetcode350:两个数组的交集 II
算法·leetcode·数组·哈希表·python3
_Itachi__19 分钟前
LeetCode 热题 100 160. 相交链表
算法·leetcode·链表
m0_6759882322 分钟前
Leetcode1206:设计跳表
算法·leetcode·跳表·python3
冠位观测者23 分钟前
【Leetcode 每日一题 - 扩展】1512. 好数对的数目
数据结构·算法·leetcode
Joyner201824 分钟前
python-leetcode-路径总和 III
算法·leetcode·职场和发展
南宫生24 分钟前
力扣每日一题【算法学习day.133】
java·学习·算法·leetcode
_Itachi__25 分钟前
LeetCode 热题 100 560. 和为 K 的子数组
数据结构·算法·leetcode
夏末秋也凉25 分钟前
力扣-贪心-55 跳跃游戏
算法·leetcode·游戏