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;
    }
};
相关推荐
那个村的李富贵5 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿5 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐5 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia16 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了6 小时前
数据结构之树(Java实现)
java·算法
算法备案代理6 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.6 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦7 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总7 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68897 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法