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;
    }
};
相关推荐
美团程序员几秒前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
.YM.Z42 分钟前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong3451 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***48071 小时前
【Golang】slice切片
开发语言·算法·golang
墨染点香1 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子1 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表
做怪小疯子3 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
努力学习的小廉3 小时前
我爱学算法之—— BFS之最短路径问题
算法·宽度优先
高山上有一只小老虎4 小时前
构造A+B
java·算法
木头左4 小时前
缺失值插补策略比较线性回归vs.相邻填充在LSTM输入层的性能差异分析
算法·线性回归·lstm