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;
    }
};
相关推荐
小O的算法实验室21 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法