LeetCode Hot100 自用

1. 两数之和

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        map<int, int> mp;
        int sz = nums.size();
        for(int i = 0; i < sz; i++) mp[target - nums[i]] = i+1;
        for(int i = 0; i < sz; i++) if(mp[nums[i]] && mp[nums[i]]-1 != i) return {mp[nums[i]]-1, i};
        return {};
    }
};

5. 最长回文子串

cpp 复制代码
class Solution {
public:
    string longestPalindrome(string s) {
    int sz = s.size();
    for(int len = sz; len >= 1; len--)
    {
    	int c = (len - 1) / 2;
        if(len % 2 != 0) 
        {
            for(; c + len / 2 < sz; c++)
            {
                int d = 1;
                for(; d <= len / 2; d++)
                {
                    if(s[c-d] != s[c+d]) break;
                }
                if(d > len / 2) return s.substr(c-(d-1), len);
            }
        }
        else
        {
            for(; c + len / 2 < sz; c++)
            {
                int t = c;
                for(; c - t <= len / 2 - 1; t--)
                {
                    if(s[t] != s[2 * c - t + 1]) break;
                }
                if(c - t > len / 2 - 1) return s.substr((t+1), len);
            }

        }
    }
    
    return s.substr(0,1);
    }
};

6. Z 字形变换

cpp 复制代码
class Solution {
public:
    string convert(string s, int numRows) {
        int r = numRows;
        string ss[1010];

        int sz = s.size();
        int rx = -1; int d = 1;
        for(int i = 0; i < sz; i++)
        {
            rx += d;
            ss[rx] += s[i];
            if(r == 1) {d = 0;}
            else if(rx == r-1) {d = -1;}
            else if(rx == 0) {d = 1;}
        }

        string ans;
        for(int i = 0; i < r; i++) ans += ss[i];
        return ans;
    }
};

7. 整数反转

(一开始没看到不许用int64的要求^^)

cpp 复制代码
using ll = long long;
class Solution {
public:
    int reverse(int x) {
        ll maxx = (1ll << 31) - 1;
        ll minn = -maxx - 1;
        
        if(x == 0) return 0;
        int sign = x < 0 ? -1 : 1;
        ll xx = x;
        xx = abs(xx);
        string s = to_string(xx);
        ::reverse(s.begin(), s.end());
        int notz = 0;
        while(s[notz] == '0') notz++;
        s = s.substr(notz);
        if(sign < 0) s = "-" + s;
        xx = stoll(s);
        if(xx > maxx || xx < minn) xx = 0;
        return (int)xx;
    }
};

(正解√)

cpp 复制代码
class Solution {
public:
    int reverse(int x) {

        if(x == 0) return 0;

        uint mx = ((uint)1 << 31) - 1;
        uint mn = 1 << 31;
        string sx = to_string(mx);
        string sn = to_string(mn);

        string s = to_string(x);
        ::reverse(s.begin(), s.end());
        int notz = 0;
        while(s[notz] == '0') notz++;
        s = s.substr(notz);

        int ans = 0;
        if(s.back() == '-')
        {
            s.pop_back();
            if(s.size() > sn.size()) return 0;
            else if(s.size() == sn.size() && s > sn) return 0;
            s = "-" + s;
        }
        else
        {
            if(s.size() > sx.size()) return 0;
            else if(s.size() == sx.size() && s > sx) return 0;
        }

        ans = stoi(s);
        return ans;
    }
};
相关推荐
naruto_lnq16 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq16 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq17 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)18 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi18 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱18 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头18 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头19 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱20 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法
罗湖老棍子20 小时前
括号配对(信息学奥赛一本通- P1572)
算法·动态规划·区间dp·字符串匹配·区间动态规划